当前位置: 首页 > news >正文

力扣119双周赛

第 119 场双周赛

文章目录

  • 第 119 场双周赛
    • 找到两个数组中的公共元素
    • 消除相邻近似相等字符
    • 最多 K 个重复元素的最长子数组
    • 找到最大非递减数组的长度

找到两个数组中的公共元素

模拟

class Solution {
public:vector<int> findIntersectionValues(vector<int>& nums1, vector<int>& nums2) {unordered_map<int,int> mp1 , mp2;vector<int>res(2);for(auto x : nums1){mp1[x] ++;}for(auto x : nums2){mp2[x] ++;}int k = 0;for(auto x : nums1){if(mp2[x] > 0)k ++;}res[0] = k;k = 0;for(auto x : nums2){if(mp1[x] > 0)k ++;}res[1] = k;return res;}
};

消除相邻近似相等字符

贪心,一个变了下一个肯定不用变

class Solution {
public:int removeAlmostEqualCharacters(string word) {int n = word.size() , ans = 0;for(int i = 1 ; i < n ; i ++)if(abs(word[i] - word[i-1]) <= 1)ans ++,i ++;return ans;}
};

最多 K 个重复元素的最长子数组

滑动窗扣维持k个

class Solution {
public:int maxSubarrayLength(vector<int>& nums, int k) {int n = nums.size();unordered_map<int,int>m;queue<int>q;int ans = 0;for(int i = 0 ; i < n ; i ++){m[nums[i]] ++;q.push(nums[i]);while(m[nums[i]] > k){int t = q.front();q.pop();m[t] --;}int l = q.size();ans = max(ans , l);}return ans;}
};

找到最大非递减数组的长度

二进制枚举+Floyd

class Solution {
public:static const int N = 11;int d[N][N];void init(){for(int i = 0 ; i < N ; i ++){for(int j = 0 ; j < N ; j ++){if(i == j)d[i][j] = 0;else d[i][j] = 99999;}}}int numberOfSets(int n, int md, vector<vector<int>>& roads) {int ans = 1 , cnt = roads.size();for(int i = 1 ; i <= ((1 << n) - 1) ; i ++){ //枚举//建图init();vector<int> c;vector<int> nt(15);for(int j = 0 ; j <= 10 ; j ++){if(i >> j & 1)c.push_back(j);}for(auto x : c)nt[x] = 1;for(int j = 0 ; j < cnt ; j ++){if(nt[roads[j][0]] == 1 && nt[roads[j][1]] == 1){d[roads[j][0]][roads[j][1]] = min(d[roads[j][0]][roads[j][1]],roads[j][2]);d[roads[j][1]][roads[j][0]] = min(d[roads[j][1]][roads[j][0]],roads[j][2]);                    }}function<bool()> check = [&]() -> bool{for (int kk = 0; kk < n; kk ++ )for (int ii = 0; ii < n; ii ++ )for (int jj = 0; jj < n; jj ++ )d[ii][jj] = min(d[ii][jj], d[ii][kk] + d[kk][jj]);for(int a = 0 ; a < c.size() ; a ++){for(int b = 0 ; b < c.size() ; b ++){if(d[c[a]][c[b]] > md){return false;}}}return true;};if(check())ans ++;} return ans;}
};

http://www.lryc.cn/news/257061.html

相关文章:

  • Redux,react-redux,dva,RTK
  • 基于Java SSM框架实现高校信息资源共享平台系统【项目源码+论文说明】计算机毕业设计
  • SpringMvc入坑系列(一)----maven插件启动tomcat
  • Leetcode—337.打家劫舍III【中等】
  • 列表标签的介绍与使用
  • 浅谈什么是语音芯片的白噪音支持功能:打造舒适家居与优质音频体验
  • 【QED】高昂的猫 Ⅰ
  • Redis如何做内存优化?
  • 倪海厦:教你正确煮中药,发挥最大药效
  • C++学习笔记:继承
  • 音频/视频、信息和通信技术设备安全标准UL62368-1
  • macos下安装科研绘图软件Origin
  • 安全快速地删除 MySQL 大表数据并释放空间
  • 未使用 “严格模式“(js的问题)
  • Verilog基础:$random系统函数的使用
  • 数据库Delete的多种用法
  • 鸿蒙前端开发-构建第一个ArkTS应用(Stage模型)
  • 从零开始搭建链上dex自动化价差套利程序(12)
  • MySQL 数据库如何实现 XA 规范?
  • SVN修改已提交版本的日志方法
  • ArkUI组件--Text组件
  • mysql的组合查询
  • 短视频购物系统源码:构建创新购物体验的技术深度解析
  • 暴力破解漏洞
  • 前端成神之路-CSS基础选择器
  • Endnote在word中加入参考文献及自定义参考文献格式方式
  • LeetCode力扣每日一题(Java):28、找出字符串中第一个匹配项的下标
  • Java UDP 多人聊天室简易版
  • leetcode 100.相同的树
  • 2021年第十届数学建模国际赛小美赛A题气道阻力的评估解题全过程文档及程序