BISHI54货物堆放

流程图

求解代码

java 复制代码
static class Goods{
        long w;
        long v;
        long c;

        Goods(long w,long v,long c){
            this.w = w;
            this.v = v;
            this.c = c;
        }
    }


    public static void main(String[] args) throws IOException{
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));

        int n = Integer.parseInt(br.readLine().trim());

        Goods[] goods = new Goods[n];
        long total = 0;
        for(int i=0;i<n;i++){
            String[] str = br.readLine().trim().split("\\s+");
            long w = Long.parseLong(str[0]);
            long v = Long.parseLong(str[1]);
            long c = Long.parseLong(str[2]);

            goods[i]=new Goods(w, v,c);
            total += v;
        }

        Arrays.sort(goods,(x,y)->Long.compare(x.c*y.w, y.c*x.w));

       // 总实际体积 = 初始体积总和 - sumCW,因此最大化sumCW是实现最小体积的关键
        long sumCW = 0;
        // 记录当前遍历商品的「上方总重量」,初始为0(第一个商品在最顶部,上方无重量)
        long upperWeight = 0;

        // 按"从上到下"的堆叠顺序遍历排序后的商品
        for (Goods g : goods) {
            // 计算当前商品的压缩贡献值:c_i × 上方总重量(W_i)
            // 这里必须先计算贡献,再更新上方重量(避免把当前商品算入自己的上方)
            sumCW += g.c * upperWeight;

            // 更新上方总重量:当前商品会成为后续商品的"上方重量",需累加其重量
            upperWeight += g.w;
        }

        long res = total -sumCW;

        out.println(res);
        out.flush();
        out.close();
        br.close();
    }
相关推荐
zhangren024683 小时前
Laravel6.x核心特性全解析
开发语言·c++·php
菜鸟中的拖拉机3 小时前
Python之conda创建虚拟环境
开发语言·python·conda
格林威3 小时前
Baumer相机芯片引脚共面性检测:保障电子装配精度的 5 个实用方案,附 OpenCV+Halcon 实战代码!
开发语言·人工智能·opencv·计算机视觉·c#·视觉检测·工业相机
黄林晴3 小时前
改完代码1秒生效,Compose热重载来了!
android
黄林晴3 小时前
紧急适配!Android 联系人权限重构,READ_CONTACTS 全面废弃
android
黄林晴3 小时前
Android 要变天:桌面端这次真的来了!
android
黄林晴3 小时前
Google 藏大招!AndroidX 悄悄上线 Remote Compose:服务端直接下发原生 UI,再也不用发版了
android
钰衡大师3 小时前
邮件头信息修改工具开发技术文档
开发语言·python
这辈子谁会真的心疼你3 小时前
怎么修改视频的拍摄信息?详细的修改过程
java·服务器·音视频
小碗羊肉3 小时前
【从零开始学Java | 第二十四篇】泛型的继承和通配符
java·开发语言·新手入门