IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 1011. 在 D 天内送达包裹的能力【C语言】 -> 正文阅读

[数据结构与算法]1011. 在 D 天内送达包裹的能力【C语言】

传送带上的包裹必须在 days 天内从一个港口运送到另一个港口。

传送带上的第 i?个包裹的重量为?weights[i]。每一天,我们都会按给出重量(weights)的顺序往传送带上装载包裹。我们装载的重量不会超过船的最大运载重量。

返回能在 days 天内将传送带上的所有包裹送达的船的最低运载能力。

示例 1:

输入:weights = [1,2,3,4,5,6,7,8,9,10], days = 5
输出:15
解释:
船舶最低载重 15 就能够在 5 天内送达所有包裹,如下所示:
第 1 天:1, 2, 3, 4, 5
第 2 天:6, 7
第 3 天:8
第 4 天:9
第 5 天:10

请注意,货物必须按照给定的顺序装运,因此使用载重能力为 14 的船舶并将包装分成 (2, 3, 4, 5), (1, 6, 7), (8), (9), (10) 是不允许的。?
?

提示:

1 <= days <= weights.length <= 5 * 104
1 <= weights[i] <= 500

这道题我们首先得说一下贪心算法二分查找:

贪心算法:这个其实就是先把问题分成若干个小问题,做出每个小问题的最优解,最后小问题的解组合到一起就是最后的解,但是贪心算法的解不一定是最大问题的最优解。

二分查找:就是说首尾遍历,最多一次循环解决问题。

这道题我们可以发现它所有的结果必定是输入数组最大值到和的区间上,只需要用贪心的方法在这个基础上遍历就可以了

int shipWithinDays(int* weights, int weightsSize, int days){
     
       int left=0,right=0;//定义左右指针
       for(int i=0;i<weightsSize;i++)
       {
            left=fmax(left,weights[i]);//寻找范围并且给两个指针赋值
            right+=weights[i];
       }

       while(left<right)//开始循环,确保左指针始终在前
       {
            int mid=(left+right)/2;//假设这一天为答案
            int need=1,w=0;//定义所需天数,这一天的重量
            
            for(int j=0;j<weightsSize;j++)//遍历开始
            {
                   if(w+weights[j]>mid)//带不上就把上一天的先带出去,然后天数加一
                   { 
                         w=0;
                         need++;
                   }
                   w+=weights[j];//如果可以带上就把下一个也带上   
            }
            if(need>days)//如果天数多了就把把范围向左移动
            {
                 left=mid+1;
            }
            else right=mid;//如果天数少了就把范围向右移动
       }
       return left;
}

执行用时:40 ms, 在所有?C?提交中击败了84.12%的用户

内存消耗:8.2 MB, 在所有?C?提交中击败了72.25%的用户

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-12-14 16:12:59  更:2021-12-14 16:14:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 16:31:39-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码