当前位置: 首页 > article >正文

Leetcode3218. 切蛋糕的最小总开销 I

题目描述:

有一个 m x n 大小的矩形蛋糕,需要切成 1 x 1 的小块。

给你整数 m ,n 和两个数组:

  • horizontalCut 的大小为 m - 1 ,其中 horizontalCut[i] 表示沿着水平线 i 切蛋糕的开销。
  • verticalCut 的大小为 n - 1 ,其中 verticalCut[j] 表示沿着垂直线 j 切蛋糕的开销。

一次操作中,你可以选择任意不是 1 x 1 大小的矩形蛋糕并执行以下操作之一:

  1. 沿着水平线 i 切开蛋糕,开销为 horizontalCut[i] 。
  2. 沿着垂直线 j 切开蛋糕,开销为 verticalCut[j] 。

每次操作后,这块蛋糕都被切成两个独立的小蛋糕。

每次操作的开销都为最开始对应切割线的开销,并且不会改变。

请你返回将蛋糕全部切成 1 x 1 的蛋糕块的 最小 总开销。

代码思路:

  1. 初始化结果
    • 首先,将horizontalCutverticalCut中所有切割位置的成本相加,得到初始的结果res。这表示仅仅进行所有给定的水平切割和垂直切割的成本总和。
  2. 计算交叉切割的额外成本
    • 接下来,代码通过两层嵌套循环遍历每一个水平切割位置hc和每一个垂直切割位置vc
    • 对于每一对交叉的切割(即一个水平切割和一个垂直切割),它们会在矩形的某个位置相交。在这个相交点,选择水平切割成本hc和垂直切割成本vc中的较小值作为交叉切割的额外成本(因为交点只会被切割一次,无论两个方向的成本如何,实际发生的成本是两者中的较小值)。
    • 将这个较小值累加到res中。
  3. 返回结果
    • 最后,返回累加后的res,它代表了进行所有给定切割以及所有交叉切割所需的最小成本总和。

代码实现:

class Solution {
public:
    int minimumCost(int m, int n, vector<int> &horizontalCut, vector<int> &verticalCut) {
        int res = std::accumulate(horizontalCut.begin(), horizontalCut.end(), 0) +
                  std::accumulate(verticalCut.begin(), verticalCut.end(), 0);
        for (const auto &hc: horizontalCut)
            for (const auto &vc: verticalCut)
                res += std::min({hc, vc});
        return res;
    }
};

 

 


http://www.kler.cn/a/452445.html

相关文章:

  • 边缘计算收益稳定
  • 数据中台从centos升级为国产操作系统后,资源增加字段时,提交报500错误
  • SpringBoot使用Validation校验参数
  • windows 默认的消息ID有那些---我与大模型对话
  • Kafka可视化工具 Offset Explorer (以前叫Kafka Tool)
  • Echarts连接数据库,实时绘制图表详解
  • WordPress Tutor LMS插件 SQL注入漏洞复现(CVE-2024-10400)
  • workman服务端开发模式-应用开发-后端api登录之浏览器版本工具开发
  • 【计算机视觉CV-图像分类】06 - VGGNet的鲜花分类实现:从数据预处理到模型优化的完整实战!
  • 【监控】夜莺监控系统各环节资源压力分析
  • 基于python的电子报实现思路
  • HarmonyOS NEXT 实战之元服务:静态案例效果--- 歌手推荐
  • 【开源免费】基于SpringBoot+Vue.JS靓车汽车销售网站(JAVA毕业设计)
  • GitLab 停止中国区用户访问,为用户提供60天的迁移期
  • 音视频入门知识(四):封装篇
  • flutter教程01 flutter项目的目录结构
  • 单片机:实现设计简单计算器(4位加减乘除)(附带源码)
  • 【AIGC】2024-CVPR-分析和改进扩散模型的训练动态
  • C-5 B样条曲线
  • OSCP课后练习-tcpdump
  • 【Object字段缺失】JS的对象在更新后发现Key值消失
  • 夸克:图片提取文字功能的优秀体验
  • 全国硕士研究生入学考试(考研)常识详解之复试考试科目:笔试、面试与加试
  • UE5.3 C++ Ceiusm中的POI 制作3DUI 结合坐标转化
  • 【day17】多线程基础
  • 【Java基础面试题046】Java中的注解原理是什么?