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

题目如上:

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

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

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

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

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

相关推荐
fegggye5 分钟前
创建一个rust写的python库
开发语言·后端·rust
全靠bug跑7 分钟前
Spring Cloud Gateway 实战:统一鉴权与用户信息全链路透传
java·开发语言·gateway·拦截器
往今~1 小时前
Matlab: 绘制GDS图纸
开发语言·matlab
ULTRA??2 小时前
插入排序算法实现(二分查找搜索版本)
c++·算法
郭涤生8 小时前
布隆过滤器
c++
喵了meme9 小时前
C语言实战4
c语言·开发语言
码界奇点9 小时前
Python从0到100一站式学习路线图与实战指南
开发语言·python·学习·青少年编程·贴图
智者知已应修善业9 小时前
【求中位数】2024-1-23
c语言·c++·经验分享·笔记·算法
9ilk9 小时前
【C++】--- 特殊类设计
开发语言·c++·后端
sali-tec10 小时前
C# 基于halcon的视觉工作流-章68 深度学习-对象检测
开发语言·算法·计算机视觉·重构·c#