吴冰燕 2023-04-23 09:59 采纳率: 84%
浏览 21
已结题

装箱子(C++) 难度:初阶

题目描述
小T暑假去叔叔的工厂体验生活。这天一共有N样物品需要小T把它们装入容量为S的一批箱子(共N个,从左到右依次编号1~N)中。

装箱的要求是:对每样物品,从左到右找到第一个可以还能够装下它的箱子中。

请模拟该装箱过程,并记录每件物品被放在了哪个箱子中。

输入格式
第一行两个正整数N和S。

第二行给出N个正整数Si,表示第i样物品的体积大小。

输出格式
一行N个整数,依次表示每件物品所在的箱子编号,空格隔开。

img

  • 写回答

4条回答 默认 最新

  • CSDN专家-link 2023-04-23 10:04
    关注

    定义一个长度为N的数组,数组元素最大值为S。然后将N个 Si分别放到从0开始编号的箱子,如果箱子的当前空闲值大于Si,则放入,并减去Si值

    #include <iostream>
    using namespace std;
    int main()
    {
        int N,S,box[200],i,t[200];
        cin>>N>>S;
        for(i=0;i<N;i++)
            box[i] = S;
        for(i=0;i<N;i++)
            cin>>t[i];
        for(i=0;i<N;i++)
        {
            for(int j=0;j<N;j++)
            {
                if(t[i] <= box[j])
                {
                    box[j] -= t[i];
                    cout<<j+1<<" ";
                    break;
                }
            }
        }
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 4月23日
  • 已采纳回答 4月23日
  • 创建了问题 4月23日

悬赏问题

  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度