[c++刷题]贪心算法.N01

题目如上:

首先通过经验分析,要用最少的减半次数,使得数组总和减少至一半以上,那么第一反应就是每次都挑数组中最大的数据去减半,这样可以是每次数组总和值减少程度最大化。

代码思路:利用大根堆去找数据中的最大值,每次减半再次压入大根堆即可。

主要是如何证明贪心策略的正确性 :

我们使用《交换论证法》来证明

圆圈代表每次减半的数,圆圈的个数就代表总操作次数。

相关推荐
惊讶的猫21 小时前
LSTM论文解读
开发语言·python
獨枭1 天前
C# 本地项目引用失效与恢复全攻略
开发语言·c#·visual studio
随意起个昵称1 天前
【递归】二进制字符串中的第K位
c++·算法
国服第二切图仔1 天前
Rust开发之Trait 定义通用行为——实现形状面积计算系统
开发语言·网络·rust
mjhcsp1 天前
C++ 循环结构:控制程序重复执行的核心机制
开发语言·c++·算法
A阳俊yi1 天前
Spring Data JPA
java·开发语言
csbysj20201 天前
CSS 对齐
开发语言
爱吃巧克力的程序媛1 天前
将qt界面中加载css或者qss样式
开发语言·css·qt
njxiejing1 天前
Python进度条工具tqdm的安装与使用
开发语言·python