【LeetCode题解】2809. 使数组和小于等于 x 的最少时间+2788. 按分隔符拆分字符串+410. 分割数组的最大值

文章目录

        • [2809. 使数组和小于等于 x 的最少时间](https://leetcode.cn/problems/minimum-time-to-make-array-sum-at-most-x/)
          • 思路:
        • [2788. 按分隔符拆分字符串](https://leetcode.cn/problems/split-strings-by-separator/)
          • 思路:
        • [410. 分割数组的最大值](https://leetcode.cn/problems/split-array-largest-sum/)
            • 思路:二分查找+贪心

2809. 使数组和小于等于 x 的最少时间

在这里插入图片描述

思路:
  1. 获取两个列表的长度n,并初始化一个二维数组f,用于存储最优解。
  2. 定义一个二维数组nums,用于存储输入的两个列表中的元素,并按照第二列元素进行排序。
  3. 使用动态规划的方法,通过遍历nums数组,计算最优解。其中,f[i][j]表示将前i个元素分配到j个集合中时的最大总和。通过比较f[i-1][j]和f[i-1][j-1]+a+b*j的大小,更新f[i][j]。
  4. 计算两个列表中所有元素的和,分别存储在s1和s2中。
  5. 遍历0至n的范围,判断是否满足条件s1 + s2 * j - f[n][j] <= x,若满足则返回j。
  6. 若没有满足条件的j值,则返回-1
class Solution {public int minimumTime(List<Integer> nums1, List<Integer> nums2, int x) {int n = nums1.size();int[][] f = new int[n + 1][n + 1]; // 定义二维数组f,用于存储最优解int[][] nums = new int[n][0]; // 定义二维数组nums,用于存储输入的两个列表中的元素for (int i = 0; i < n; ++i) {nums[i] = new int[] {nums1.get(i), nums2.get(i)}; // 将输入的两个列表中的元素按照相同的索引放入nums数组中}Arrays.sort(nums, Comparator.comparingInt(a -> a[1])); // 根据nums数组中第二列的元素进行排序for (int i = 1; i <= n; ++i) {for (int j = 0; j <= n; ++j) {f[i][j] = f[i - 1][j]; // 初始化f[i][j]为f[i-1][j]if (j > 0) { // 当j大于0时,进行以下操作int a = nums[i - 1][0], b = nums[i - 1][1];f[i][j] = Math.max(f[i][j], f[i - 1][j - 1] + a + b * j); // 更新f[i][j],取当前值与f[i-1][j-1]+a+b*j的较大值}}}int s1 = 0, s2 = 0;for (int v : nums1) {s1 += v; // 计算nums1列表中所有元素的和,存储在s1中}for (int v : nums2) {s2 += v; // 计算nums2列表中所有元素的和,存储在s2中}for (int j = 0; j <= n; ++j) {if (s1 + s2 * j - f[n][j] <= x) { // 判断是否满足条件 s1 + s2 * j - f[n][j] <= xreturn j; // 返回满足条件的j值}}return -1; // 若没有满足条件的j值,则返回-1}
}
2788. 按分隔符拆分字符串

在这里插入图片描述

思路:
  1. 对于每个单词,使用一个可变字符串 StringBuilder 来构建拆分后的单词。初始时,可变字符串为空。
  2. 遍历每个单词的每个字符,如果遇到指定的分隔符,就将可变字符串中的字符构成一个新的单词,并将其添加到结果列表中。然后清空可变字符串,准备构建下一个单词。
  3. 如果遇到的不是分隔符,则将当前字符添加到可变字符串中。
  4. 最后,如果可变字符串非空,则说明最后一个单词还没有添加到结果列表中,因此需要将其添加到结果列表中。
  5. 返回拆分后的结果列表。
//2788. 按分隔符拆分字符串public List<String> splitWordsBySeparator(List<String> words, char separator) {// 创建一个新的字符串列表,用于存储拆分后的结果List<String> res = new ArrayList<>();// 遍历原始字符串列表中的每个单词for (String word : words) {// 创建一个可变字符串,用于构建拆分后的单词StringBuilder sb = new StringBuilder();// 获取当前单词的长度int length = word.length();// 遍历当前单词的每个字符for (int i = 0; i < length; i++) {// 获取当前字符char c = word.charAt(i);// 如果当前字符是分隔符if (c == separator) {// 如果可变字符串不为空,则将其添加到结果列表中,并清空可变字符串if (sb.length() > 0) {res.add(sb.toString());sb.setLength(0);}} else {// 如果当前字符不是分隔符,则将其添加到可变字符串中sb.append(c);}}// 如果可变字符串不为空,则将其添加到结果列表中if (sb.length() > 0) {res.add(sb.toString());}}// 返回拆分后的字符串列表return res;}
410. 分割数组的最大值

在这里插入图片描述

思路:二分查找+贪心

利用二分查找法和贪心算法来求解将数组分割为m个非空连续子数组,使得每个子数组的和的最大值最小

  1. 首先,我们需要确定二分查找的左右边界。左边界left初始化为数组中的最大值,右边界right初始化为数组所有元素的总和。
  2. 然后,我们使用二分查找法在左右边界之间查找满足条件的最小子数组和。
  3. 在每次迭代中,我们计算中间值mid,然后调用check函数判断以mid为目标值是否能将数组nums分割成不超过m个子数组。如果能,则将右边界更新为mid,因为我们要寻找更小的子数组和。如果不能,则将左边界更新为mid + 1,因为mid不满足条件,我们需要尝试更大的值。
  4. 当左边界left不小于右边界right时,二分查找结束,最终的结果即为左边界的值。
  5. 最后,返回左边界的值作为最小子数组和。
public int splitArray(int[] nums, int m) {int left = 0, right = 0;// 初始化左右边界for (int i = 0; i < nums.length; i++) {right += nums[i];if (left < nums[i]) {left = nums[i];}}// 使用二分查找法寻找最小的子数组和while (left < right) {int mid = (right - left) / 2 + left;if (check(nums, mid, m)) {right = mid;} else {left = mid + 1;}}// 返回最小的子数组和return left;
}public boolean check(int[] nums, int x, int m) {int sum = 0;int cnt = 1;// 统计满足条件的子数组个数for (int i = 0; i < nums.length; i++) {if (sum + nums[i] > x) {// 当前元素加上之后超过了目标值,需要分割出一个新的子数组cnt++;sum = nums[i];} else {// 将当前元素加入到当前子数组中sum += nums[i];}}// 判断最终的子数组个数是否小于等于目标个数return cnt <= m;
}

check函数中,遍历数组nums,累加元素值到sum变量中,如果累加和超过了目标值x,则说明当前子数组和超过了目标值,需要分割出一个新的子数组,同时将子数组计数cnt增加1,并将sum重置为当前元素值。如果累加和未超过目标值,则将当前元素加入到当前子数组中。

最后,判断最终的子数组个数cnt是否小于等于目标个数m,如果是则返回true,否则返回false

通过不断调整二分查找的左右边界,可以找到满足条件的最小子数组和

点击移步博客主页,欢迎光临~

偷cyk的图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/508542.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

设计模式(十三)抽象工厂模式

请直接看原文:设计模式&#xff08;十三&#xff09;抽象工厂模式_抽象工厂模式告诉我们,要针对接口而不是实现进行设计。( )-CSDN博客 -------------------------------------------------------------------------------------------------------------------------------- …

通信原理:通信的基本概念(第一节课)

1.通信的基本概念 1.1消息&#xff0c;信息与信号 我们先看一个调幅AM无线广播系统 我们信号举个例子&#xff1a; 可以看出&#xff0c;我们研究的参量不一样&#xff0c;对应的模拟和数字信号也会与我们看上去的不同。 信息&#xff1a; 生活中的例子来认识一下&#xff1…

Python——桌面摄像头软件(附源码+打包)

目录 一、前言 二、桌面摄像头软件 2.1、下载项目 2.2、功能介绍 三、打包工具&#xff08;nuitka&#xff09; 四、项目文件复制&#xff08;我全部合到一个文件里面了&#xff09; 五、结语 一、前言 看见b站的向军大叔用electron制作了一个桌面摄像头软件 但是&#x…

LabVIEW起重机工作参数远程监测系统

LabVIEW起重机工作参数远程监测系统 随着起重机技术的持续发展&#xff0c;对其工作参数的实时监控需求日益增加。设计了一个基于LabVIEW和TBox的起重机工作参数远程监测系统&#xff0c;能够实现起重机工作参数的实时采集、传输、解析和显示&#xff0c;有效提升起重机的性能…

自动化测试介绍、selenium用法(自动化测试框架+爬虫可用)

文章目录 一、自动化测试1、什么是自动化测试&#xff1f;2、手工测试 vs 自动化测试3、自动化测试常见误区4、自动化测试的优劣5、自动化测试分层6、什么项目适合自动化测试 二、Selenuim1、小例子2、用法3、页面操作获取输入内容模拟点击清空文本元素拖拽frame切换窗口切换/标…

【计算机网络】HTTPS 协议原理

https 一、HTTPS 是什么二、加密1. 加密概念2. 加密的原因3. 常见的加密方式&#xff08;1&#xff09;对称加密&#xff08;2&#xff09;非对称加密 三、数据摘要(数据指纹)四、HTTPS 的工作原理探究1. 只使用对称加密2. 只使用非对称加密3. 双方都使用非对称加密4. 非对称加…

信息系统项目管理师--项目立项管理

项⽬⽴项管理是对拟规划和实施的项⽬技术上的先进性、适⽤性&#xff0c;经济上的合理性、效益性&#xff0c;实施上的可能性、⻛险性以及社会价值的有效性、可持续性等进⾏全⾯科学的综合分析&#xff0c; 为项⽬决策提供客观依据的⼀种技术经济研究活动 项⽬建议与⽴项申请、…

代码随想录第46天|● 121. 买卖股票的最佳时机 ● 122.买卖股票的最佳时机II

文章目录 ● 121. 买卖股票的最佳时机思路一&#xff1a;贪心&#xff08;效率最快&#xff09;代码&#xff1a; 思路二&#xff1a;动态规划-dp数组代码&#xff1a; 思路三&#xff1a;动态规划 常数储存代码&#xff1a; ● 122.买卖股票的最佳时机II思路一&#xff1a;动态…

微信小程序(四十九)拦截器处理登入失败情况

注释很详细&#xff0c;直接上代码 上一篇 新增内容&#xff1a; 1.拦截器判断处理失败与成功的情况 2.使用拦截器拒绝失败的情况&#xff0c;使网络请求后面的逻辑步骤不会执行 源码&#xff1a; index.wxml <button type"primary" bind:tap"onSubmit"…

Java面试题总结200道(二)

26、简述Spring中Bean的生命周期&#xff1f; 在原生的java环境中&#xff0c;一个新的对象的产生是我们用new()的方式产生出来的。在Spring的IOC容器中&#xff0c;将这一部分的工作帮我们完成了(Bean对象的管理)。既然是对象&#xff0c;就存在生命周期&#xff0c;也就是作用…

C#,无监督的K-Medoid聚类算法(K-Medoid Algorithm)与源代码

1 K-Medoid算法 K-Medoid&#xff08;也称为围绕Medoid的划分&#xff09;算法是由Kaufman和Rousseeuw于1987年提出的。中间点可以定义为簇中的点&#xff0c;其与簇中所有其他点的相似度最小。 K-medoids聚类是一种无监督的聚类算法&#xff0c;它对未标记数据中的对象进行聚…

【DIY】超重低音耳机放大器的制作

这不是一款普通的耳机放大器&#xff0c;我在它前级加入低音提升电路后&#xff0c;可以让你使用耳机听到高保真的音响效果&#xff0c;特别是重低音效果&#xff0c;逼真感很强以至于用它听的时间长了会让人感到头晕&#xff0c;使用它必须得注意&#xff1a;你的耳机要能经得…