CodeDance2023 2024-03-01 01:07 采纳率: 96%
浏览 11
已结题

木材加工问题部分答案错误

img

img

img


oj说答案错误,边界 处理了,防止溢出开了long long的数组,实在找不出哪里错了,你们能看出哪里错了吗,必采纳


#include <iostream>
using namespace std;
typedef long long ll;
ll L[100005]; //储存原木的长度
ll n, k, l, r,mid,cnt,ans,Max = 0,sum = 0;
ll check(ll x)
{
    cnt = 0;
    for (ll i = 1; i <= n; ++i)
    {
        cnt += L[i] / x;       //循环累加取整数求出段数
    }
    if (cnt > k)        //段数多了
    {
        return 1;
    }
    else if (cnt == k)
    {
        ans = x;        //答案符合要求,保存当时的长度答案
        return 0;
    }
    else return -1;   //段数少了
}
int main()
{
    cin >> n >> k;
    for (ll i = 1; i <= n; ++i)
    {
        cin >> L[i];
        if (L[i] > Max) Max = L[i];  //找出原木的最大长度,作为答案的右边界
        sum += L[i];         //求出长度总和
    }
    if (sum < k)     //总和小于段数,1cm也切不出,直接输出0
    {
        cout << 0;
        return 0;
    }
        
    l = 0;      //最少为0cm
    r = Max;    //最多设为n根原木中的最大长度
    while (l < r)
    {
        mid = (l + r + 1) >> 1; //可能会溢出
        if (check(mid) == 0 || check(mid) == 1)     //段数多了,说明长度太短了,增大一点;如果刚好相等,继续增大长度,找最优解
        {
            l = mid;
        }
        else if (check(mid) == -1)    //段数少了,说明长度太长了,减小一点
        {
            r = mid - 1;               
        }
    }
    cout << ans;
    return 0;
}
  • 写回答

1条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2024-03-01 10:10
    关注

    【相关推荐】




    如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月13日
  • 已采纳回答 3月5日
  • 创建了问题 3月1日

悬赏问题

  • ¥15 求京东批量付款能替代天诚
  • ¥15 slaris 系统断电后,重新开机后一直自动重启
  • ¥15 51寻迹小车定点寻迹
  • ¥15 谁能帮我看看这拒稿理由啥意思啊阿啊
  • ¥15 关于vue2中methods使用call修改this指向的问题
  • ¥15 idea自动补全键位冲突
  • ¥15 请教一下写代码,代码好难
  • ¥15 iis10中如何阻止别人网站重定向到我的网站
  • ¥15 滑块验证码移动速度不一致问题
  • ¥15 Utunbu中vscode下cern root工作台中写的程序root的头文件无法包含