力扣labuladong一刷day24天

力扣labuladong一刷day24天

文章目录

      • 力扣labuladong一刷day24天
      • 一、875. 爱吃香蕉的珂珂
      • 二、1011. 在 D 天内送达包裹的能力
      • 三、410. 分割数组的最大值

一、875. 爱吃香蕉的珂珂

题目链接:https://leetcode.cn/problems/koko-eating-bananas/?utm_source=LCUS&utm_medium=ip_redirect&utm_campaign=transfer2china
思路:本质上是一个二分搜索左边界的问题,每个小时吃多少都可以,要找的是每小时吃k个,h个小时正好吃完,抽取出来计算用多少小时吃完的函数,小时数超了应该扩大k,小时数少了应该缩小k。

class Solution {public int minEatingSpeed(int[] piles, int h) {int left = 1, right = 1000000000;while (left <= right) {int mid = left + (right - left) / 2;if (f(mid, piles) <= h) {right = mid - 1;}else {left = mid + 1;}}return left;}long f(int k, int[] piles) {long h = 0;for (int i = 0; i < piles.length; i++) {h += piles[i] / k;if (piles[i] % k > 0) {h++;}}return h;}
}

二、1011. 在 D 天内送达包裹的能力

题目链接:https://leetcode.cn/problems/capacity-to-ship-packages-within-d-days/
思路:这题类似上一题,有 一个容量K,要求在day天运送完成所使用的最小k。在left和right的选取上要先设置好范围,最小就是最小的包裹,最大就是全体都能放下。计算天数时注意结尾的处理,最后没装满或者装多了只要不是正好是0都要多加1天。

class Solution {public int shipWithinDays(int[] weights, int days) {int left = 0;int right = 1;for (int w : weights) {left = Math.max(left, w);right += w;}while (left <= right) {int mid = left + (right - left) / 2;if (f(weights, mid) <= days) {right = mid - 1;}else {left = mid + 1;}}return left;}int f(int[] weights, int x) {int day = 0, sum = 0;for (int i = 0; i < weights.length; i++) {if (sum+weights[i] == x) {day++;sum = 0;}else if (sum + weights[i] < x) {sum += weights[i];}else {day++;sum = weights[i];}}return sum == 0 ? day : day+1;}
}

三、410. 分割数组的最大值

题目链接:https://leetcode.cn/problems/split-array-largest-sum/
思路:把数组顺序分成k个区间,要求所有的分法当中各个和最大区间的 最小值。其实也就是有很多货物,让k天运完,求船的最小容量,
一样是先确定left和right的边界,边界里的数是船的容量,不可能说船的容量装不下某一个货物,故left应该是所有货物中的最大值。right的话看天数要求,天数最少1天,right最大为货物总和。
f(mid) 与 k如何调节,其实直接分析就行,怎么写都可以,加入写成f(mid) <= k 那么说明船容量太大,导致天数少了,所以缩小容量天数就大了,即right = mid -1;
else就是 f(mid) > k 那么就是船的容量太小,导致天数多了,故扩大容量让天数变下,left = mid + 1;

class Solution {public int splitArray(int[] nums, int k) {int left = 0, right = 0;for (int i : nums) {left = Math.max(left, i);right += i;}while (left <= right) {int mid = left + (right - left) / 2;if (f(nums, mid) <= k) {right = mid - 1;}else {left = mid + 1;}}return left;}int f(int[] nums, int c) {int m = 0, sum = 0;for (int i = 0; i < nums.length; i++) {if (sum + nums[i] == c) {m++;sum = 0;} else if (sum + nums[i] < c) {sum += nums[i];}else {m++;sum = nums[i];}}return sum == 0 ? m : m + 1;}
}

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

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

相关文章

数据结构——堆排序的topk问题

呀哈喽&#xff0c;我是结衣 前言 今天给大家带来的堆排序的topk问题。topk就是在许多数中&#xff0c;找出前k个大的数&#xff0c;可能是几十个数&#xff0c;也可能是几千万个数中找。今天我们将要在1000000&#xff08;一百万&#xff09;个数中找出前10大的数。 知识点 C…

【c】角谷猜想

#include<stdio.h> int coll(int x)//定义函数 {int count0;while(x>1){if(x%20){xx/2;count;}else{x3*x1;count;}}return count; } int main() {int n,num;scanf("%d",&n);int arr[n1];for(int i1;i<n;i)//输入n组数据保存到数组中{scanf("%d&…

数据结构之哈希表

数据结构之哈希表 文章目录 数据结构之哈希表一、哈希概念二、哈希冲突三、哈希函数常见哈希函数 四、哈希冲突解决闭散列闭散列的思考线性探测线性探测的实现 二次探测 开散列开散列概念开散列的思考开散列实现 五、开散列与闭散列比较 一、哈希概念 顺序结构以及平衡树中&am…

为获取导入百分比,使用easyexcel获取导入excel表总行数

背景 分批读取大量数据的excel文件&#xff0c;每次读取1000行数据&#xff0c;然后插入数据库&#xff0c;并且去执行一个方法&#xff0c;执行完毕后更新此行数据的状态。需要获取已更新数据的占比&#xff0c;即计算百分比。 因为是分批读取的&#xff0c;我们不可以直接用已…

CPP-SCNUOJ-Problem P26. [算法课动态规划] 打家劫舍

Problem P26. [算法课动态规划] 打家劫舍 你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋。每间房内都藏有一定的现金&#xff0c;影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统&#xff0c;如果两间相邻的房屋在同一晚上被小偷闯入&#xff0c;系统会自动…

LeetCode每日一题 | LeetCode-1094.拼车

LeetCode-1094.拼车 题目描述问题分析程序代码 题目描述 原题链接 车上最初有 capacity 个空座位。车 只能 向一个方向行驶&#xff08;也就是说&#xff0c;不允许掉头或改变方向&#xff09; 给定整数 capacity 和一个数组 trips , trip[i] [numPassengersi, fromi, toi] 表…

14.Oracle中RegExp_Like 正则表达式基本用法

--基本用法&#xff0c;是否包含某字符串 like %36% select * from k_micfo where regexp_like(loginid,36);if regexp_like(str,^[0-9\.]$) --只包含数字0-9&#xff0c;,小数点.--oracle判断字段是否是纯数字 (四种写法结果一样&#xff09; select * from k_micfo where r…

SpringCloudAlibaba整合Gateway实现网关

目录 一、概念 二、整合Gateway实现网关 三、Gateway实现转发 四、Gateway实现请求过滤 一、概念 Gateway是一种基于SpringC

第十节HarmonyOS 使用资源引用类型

Resource是资源引用类型&#xff0c;用于设置组件属性的值。推荐大家优先使用Resource类型&#xff0c;将资源文件&#xff08;字符串、图片、音频等&#xff09;统一存放于resources目录下&#xff0c;便于开发者统一维护。同时系统可以根据当前配置加载合适的资源&#xff0c…

paddle 语谱图对比

paddle 语谱图对比 代码代码解析结论代码 import paddle from paddleaudio import load from paddleaudio.features import LogMelSpectrogram,MFCC,Spectrogram,MelSpectrogramfrom matplotlib import pyplot as pltdata, sr = load

MidJourney笔记(6)-Niji模式

Niji模式 回顾一下,在讲解settings命令时,我们可以看到一个Niji字眼。 而且是在Midjourney V4之后才有的,那Niji到底是什么? Niji是MidJourney中用于绘制二次元/动漫风格的模型,那Niji的V4和V5有什么区别呢?

简单理解算法

简单理解算法 前言算法衡量一个好的算法具备的标准算法的应用场景 数据结构数据结构的组成方式 前言 hello&#xff0c;宝宝们~来分享我从一本书中理解的算法。《漫画算法》感觉对我这种算法小白比较友好。看完感觉对算法有了新的理解&#xff0c;计算机学习这么多年&#xff…

H265、VP9、AV1视频编码器性能对比

1、背景介绍 目前在视频编解码器中,H264 已经成为绝对的主流,被大部分设备、浏览器所支持。虽然有更先进的编码器推出,但是受限于推广速度和设备支持成本,一直未能成为主流。 今年公司的目标是持续降本增效,现在将”屠刀“指向了视频业务的存储成本。视频文件存储主要两…

竞赛选题 : 题目:基于深度学习的水果识别 设计 开题 技术

1 前言 Hi&#xff0c;大家好&#xff0c;这里是丹成学长&#xff0c;今天做一个 基于深度学习的水果识别demo 这是一个较为新颖的竞赛课题方向&#xff0c;学长非常推荐&#xff01; &#x1f9ff; 更多资料, 项目分享&#xff1a; https://gitee.com/dancheng-senior/pos…

ChatGPT等大语言模型为什么没有智能

今天我们来闲聊聊chatGPT&#xff0c;然后带出一些目前神经网络或者更大一些人工智能存在的问题&#xff0c;仅作抛砖引玉。我不管OpenAI用什么方式炒作&#xff0c;Q*也好&#xff0c;AI自我意识也好&#xff0c;董事会内斗也罢&#xff1b;首先它的成绩还是非常出色的&#x…

编程实战:类C语法的编译型脚本解释器(系列)

“脚本”始终是个具有独特魅力的领域&#xff0c;能够随时方便地解决一些问题&#xff0c;但脚本的随意性同时带来别的问题&#xff0c;所以脚本始终属于让人又爱又恨的存在。 很多大型系统都会嵌入一些小型的解释器&#xff0c;用来让用户亲自编写简单的逻辑规则。不幸的是&am…

springCache——jetcache缓存

文章目录 jetcache远程、本地缓存方案jetcache方法注解使用方式 jetcache远程、本地缓存方案 <dependency><groupId>com.alicp.jetcache</groupId><artifactId>jetcache-starter-redis</artifactId><version>2.6.4</version></de…

[c]比较月亮大小

本题的难点就是分情况讨论 #include<stdio.h> int main() {int n;scanf("%d",&n);int arr2[n];int p;for(int m0;m<n-1;m){scanf("%d",&arr2[m]);//输入n个数保存到数组}if(n1)//当输入一个数据时&#xff0c;输入0&#xff0c;可以判断…

如何进行Java项目的构建和部署?

Java项目的构建和部署可以使用一些常用的工具来完成&#xff0c;如Maven、Gradle和Ant等。 Maven构建和部署Java项目&#xff1a; Maven是一个Java项目管理工具&#xff0c;通过在项目的pom.xml文件中声明依赖和插件来管理项目。使用Maven进行Java项目的构建和部署可以按照以下…

Java中实现HTTPS连接的最佳实践

引言 大家好&#xff01;我是小黑。今天咱们来聊聊一个既热门又实用的话题&#xff1a;在Java中如何实现HTTPS连接。现在的网络世界&#xff0c;安全性是大家都非常关注的问题&#xff0c;特别是对于咱们这些程序员来说&#xff0c;更是如此。想想看&#xff0c;如果你的网站或…