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

贵州网站集约化建设许昌网站制作公司

贵州网站集约化建设,许昌网站制作公司,wordpress手机电影,河东网站建设1439. 有序矩阵中的第 k 个最小数组和 难度困难120 给你一个 m * n 的矩阵 mat#xff0c;以及一个整数 k #xff0c;矩阵中的每一行都以非递减的顺序排列。 你可以从每一行中选出 1 个元素形成一个数组。返回所有可能数组中的第 k 个 最小 数组和。 示例 1#xff1a;…1439. 有序矩阵中的第 k 个最小数组和 难度困难120 给你一个 m * n 的矩阵 mat以及一个整数 k 矩阵中的每一行都以非递减的顺序排列。 你可以从每一行中选出 1 个元素形成一个数组。返回所有可能数组中的第 k 个 最小 数组和。 示例 1 输入mat [[1,3,11],[2,4,6]], k 5 输出7 解释从每一行中选出一个元素前 k 个和最小的数组分别是 [1,2], [1,4], [3,2], [3,4], [1,6]。其中第 5 个的和是 7 。 示例 2 输入mat [[1,3,11],[2,4,6]], k 9 输出17示例 3 输入mat [[1,10,10],[1,4,5],[2,3,6]], k 7 输出9 解释从每一行中选出一个元素前 k 个和最小的数组分别是 [1,1,2], [1,1,3], [1,4,2], [1,4,3], [1,1,6], [1,5,2], [1,5,3]。其中第 7 个的和是 9 。 示例 4 输入mat [[1,1,10],[2,2,9]], k 7 输出12提示 m mat.lengthn mat.length[i]1 m, n 401 k min(200, n ^ m)1 mat[i][j] 5000mat[i] 是一个非递减数组 二分查找解决第k小问题 https://leetcode.cn/problems/find-the-kth-smallest-sum-of-a-matrix-with-sorted-rows/solution/by-lfool-w2ul/ 719. 找出第 K 小的数对距离 1439. 有序矩阵中的第 k 个最小数组和 我们先明确一下原问题「返回所有可能数组中的第 k 个最小数组和」 对于一个给定的数组和 sum如果该数组和小了那我们就「向右收缩」如果该数组和大了那我们就「向左收缩」如果该数组和满足要求那我们能不能找一个更小的且满足要求的数组和所以需要继续「向左收缩」(是不是很像「寻找最左相等元素」自信点就是「寻找最左相等元素」) 所以「搜索对象」是什么很明显就是「数组和」嘛 那「搜索范围」又是什么呢 数组和最小值可以到达多少肯定是该矩形的第一列组成的组数和嘛 (矩形每行递增)数组和最大值可以到达多少肯定是该矩形的最后一列组成的组数和嘛 (矩形每行递增) 明确了「搜索对象」和「搜索范围」我们还需要搞清楚怎么确定数组和小了还是大了肯定要有一个参考对象才能确定近还是远嘛 很聪明这个参考对象就是题目给的「第 k 最小」。对于数组和 sum小于等于该数组和的数量为 n如果 n k 说明数组和小了如果 n k 说明数组和大了 class Solution {// https://leetcode.cn/problems/find-the-kth-smallest-sum-of-a-matrix-with-sorted-rows/solution/by-lfool-w2ul/int m, n, k;int[][] mat;int cnt 0; // 计算小于等于当前数组和的数量public int kthSmallest(int[][] mat, int k) {this.k k;this.mat mat;m mat.length;n mat[0].length;// 搜索范围int left 0, right 0;for (int i 0; i m; i) {left mat[i][0];right mat[i][n - 1];}// 把最小值设为初始值int init left;while (left right) {int mid left - (left - right) / 2;// 初始值也算一个可行解cnt 1;dfs(0, init, mid);// 对应数组和大了向左收缩if (cnt k) right mid - 1;// 对应数组和小了向右收缩else left mid 1;}return left;}// DFS 计算 小于等于 target 的数量private void dfs(int row, int sum, int target) {// 特殊情况直接返回// sum target当前数组和大于 target// cnt k当前小于等于 target 的数量大于 k// row m已经到达最后一行 (结束条件)if (sum target || cnt k || row m) return;// 不做交换dfs(row 1, sum, target);// 分别与 [1, n-1] 交换for (int i 1; i n; i) {// 更新数组和减去「第一个元素」加上「要交换的元素」int newSum sum - mat[row][0] mat[row][i];// 交换后的数组和大于 target直接跳出循环// 原因由于每行元素递增所以当前元素大了该行后面的元素肯定也大了if (newSum target) break;// 满足要求cnt 1cnt;// 搜索下一行dfs(row 1, newSum, target);}} }多路归并 题解https://leetcode.cn/problems/find-the-kth-smallest-sum-of-a-matrix-with-sorted-rows/solution/by-lfool-z9n4/ class Solution {// 对于每次弹出队顶元素后需要把 n 个元素入队public int kthSmallest(int[][] mat, int k) {int m mat.length, n mat[0].length;SetString set new HashSet();// 构造一个最小堆PriorityQueueint[] q new PriorityQueue((a, b) - a[m] - b[m]);// init[0..m-1] 存储矩阵的一列元素的下标// init[m]存储该列的和int[] init new int[m1];for(int i 0; i m; i){init[m] mat[i][0];init[i] 0;}q.offer(init);set.add(Arrays.toString(init));while(k-- 0){int[] cur q.poll();if(k 0) return cur[m];// 构造处需要加入堆的元素一共m个for(int i 0; i m; i){int[] tmp (int[])Arrays.copyOf(cur, m1);if(tmp[i] 1 n)continue; // 下标越界了tmp[m] mat[i][tmp[i] 1] - mat[i][tmp[i]]; // 下标i往前进tmp[m]处增加上变化量tmp[i] 1;String s Arrays.toString(tmp);if(set.contains(s)) continue;q.offer(tmp);set.add(s);}}return -1;} }多路归并练习题 264. 丑数 II 313. 超级丑数 373. 查找和最小的 K 对数字 786. 第 K 个最小的素数分数 1508. 子数组和排序后的区间和 719. 找出第 K 小的数对距离 1439. 有序矩阵中的第 k 个最小数组和
http://www.dnsts.com.cn/news/180244.html

相关文章:

  • 百度收录网站关键字wordpress做门户网
  • 有哪些网站是用vue做的济南天桥区网站建设
  • 中卫建设厅网站做网站前期需要准备什么
  • 家居企业网站建设机构笑话网站模版
  • 商务网站规划与网页制作网站网站怎么优化关键词排名
  • 网站备案要如何取消室内设计效果图制作教程
  • 模块网站需要多少钱怎么做平台网站吗
  • 大型网站外链是怎么建设的建设银行官网入口
  • 贵阳做网站方舟网络网站保定网站建设多少钱
  • 做体育网站做会所网站的
  • 湖北建设厅行政服务中心网站网站上线流程
  • 德源网站建设凡科网站可以做淘宝客吗
  • 洋洋点建站net网站建设教程
  • 目前建设网站做直播网站需要多少钱
  • 做底单的网站怎样做好网站用户体验
  • 我司网站改版上线网站建设wordpress后台排版错乱
  • 怎么在网站里做网页山东鲁桥建设有限公司网站
  • 广东省建设教育协会官方网站区块链app定制
  • 江都建设局网站网站平台搭建技术
  • 外发加工网有哪些北京中文seo
  • 网站icp备案号是如何编制的wordpress此网页包含重定向循环
  • 南昌企业建站系统模板设计一个创新产品
  • 中国容桂营销网站建设大连展厅设计公司
  • 做网站人才技术支持 重庆网站
  • frontpage怎么做网站dw怎么把网站做的漂亮
  • 目前主流网站开发所用软件网站建设最新活动
  • 简历生成网站中机建设一公司网站
  • 怎么上传文章网站耒阳市做网站的
  • 建行网站是多少呢凡科网账号怎么注销
  • 网站seo内部优化做的比较好的教育网站