木材加工(二分查找)

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

using ll = long long;

int main(){
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    
    int n,k;
    cin>>n>>k;
    int a[100000];
    ll to=0;
    for(int i=0;i<n;i++){
        cin>>a[i];
        to+=a[i];
    }
    if(to<k){
        cout<<0;
        return 0;
    }
    
    sort(a,a+n);
    
    int l=1,r=a[n-1];// 设定最小段长为1,最大段长为最大木头的长度
    int res=0;  // 用来记录最终的最大段长度
    while(l<=r){
        int mid=l+(r-l)/2;
        int ans=0;  // 用来统计当前段长度下能够切割的木段数量
        for(int i=0;i<n;i++){
                ans+=a[i]/mid;  // 计算当前段长度能切割出多少段
            }
            if(ans>=k){ // 如果能切割出至少 k 段,则更新 res
                res=mid;
                l=mid+1;
            } else{
                r=mid-1;
            }
    }
    
    cout<<res;
    return 0;
    
    }

to 是所有木材的总长度

to < k:这意味着,如果所有木材的总长度 to 小于 k.说明无法切割出 k 段木头,直接输出 0

return 0; 立刻退出,避免后续不必要的计算。有一个测试点是这个

二分查找的核心思想

l 表示当前最小的段长度(初始为 1)。

r 表示当前最大的段长度(初始为原木的最大长度,即 a[n-1])。

每次计算 mid(中间的段长度),然后遍历所有的木头,计算每根木头能切割出多少段。用 ans 来累积切割出的段数。

如果 ans(切割出的段数)大于等于 k,说明当前的段长度 mid 是可行的,于是更新 res 并尝试增大段长度(通过设置 l = mid + 1)。

如果 ans 小于 k,说明当前的段长度过大,需要减小段长度(通过设置 r = mid - 1)。

相关推荐
TT哇12 小时前
【多源 BFS】3.地图中的最⾼点(medium)
算法·宽度优先
dllxhcjla12 小时前
数据结构与算法 第一天
数据结构·算法
再__努力1点13 小时前
【11】特征检测与匹配:AKAZE特征算法详解与实现
人工智能·python·opencv·算法·计算机视觉·特征提取
Bender_ydc13 小时前
一个基于现代 C++23 Modules 的传统文化算法库,使用纯模块化设计实现(包含大六壬、六爻、紫薇斗数、八字、奇门遁甲)
算法·c++23
Kuo-Teng13 小时前
LeetCode 141. Linked List Cycle
java·算法·leetcode·链表·职场和发展
逸风尊者13 小时前
开发需掌握的知识:高精地图
人工智能·后端·算法
洛_尘13 小时前
数据结构--9:反射、枚举以及lambda表达式(了解即可)
java·开发语言·数据结构
资深web全栈开发13 小时前
力扣2536子矩阵元素加1-差分数组解法详解
算法·leetcode·矩阵·golang·差分数组
njxiejing13 小时前
Python pandas基础:Series数据操作详解
数据结构·pandas
弘毅 失败的 mian13 小时前
C++、Java 还是测试开发?
java·c++·经验分享·笔记·测试开发·技术方向·就业