CodeDance2023 2024-03-01 00:20 采纳率: 96%
浏览 8
已结题

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

img

img

img

你们看得出哪里错了吗,边界都处理了,防止溢出也直接开了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;
}

  • 写回答

2条回答 默认 最新

  • 智者知已应修善业 2024-03-01 09:53
    关注

    整体不存在所谓的理想值

    img

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月17日
  • 已采纳回答 3月9日
  • 创建了问题 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的头文件无法包含