贪心算法:组合一组数字获得最大数
创作时间:
2025-01-22 03:59:10
作者:
@小白创作中心
贪心算法:组合一组数字获得最大数
贪心算法是一种在每一步选择中都采取当前状态下最优选择的算法策略,从而希望最终能够得到全局最优解。它通常用于解决优化问题,例如最小化成本或最大化收益。贪心算法的关键在于选择合适的贪心策略,使得每一步的局部最优选择能够最终导向全局最优解。
题目重现
给定一组非负整数 nums,重新排列每个数的顺序(每个数不可拆分)使之组成一个最大的整数。
注意:输出结果可能非常大,所以你需要返回一个字符串而不是整数。
示例 1:
输入:nums = [10,2]
输出:“210”
示例 2:
输入:nums = [3,30,34,5,9]
输出:“9534330”
读懂题目
这道题目有三个注意点:
- 组合得到的结果可能很大,返回值类型是字符串(string)
- 如果组合得到的字符串以 ‘0’ 开头,那么后续字符也只可能是 ‘0’,因为题目的核心条件是组合得到的数字尽可能大,这里返回结果需要截断后面所有字符 ‘0’,仅返回 “0” 即可。
- 最终得到的字符串需要有一定的规则决定哪个数字优先做高位被插入字符串中,所以这组数某种意义上是有序的,将这组数字按照指定顺序存入容器中,就可以逐个按顺序取出直接插入字符串,得到的结果是理想的最大数。
处理细节:
由于每次仅需取到当前容器剩余数中最符合要求的一个数字,所以符合堆的特性,我们可以选用优先队列 priority_queue 来存储这组数。
对于上面注意点中提到的以某种特定规则对这组数进行排序,这种排序规则的指定可以通过传递谓词实现,为了方便实现,我们可以定义 lambda 表达式并将其表达式自身类型和表达式对象分别传入 priority_queue 的构造模板列表和构造函数参数列表。
另外注意 priority_queue 实例化对象时的参数列表:
为了便于对这组数设定排序谓词,不妨将其全部转为字符串类型再 push 进优先队列,同时我们将要作为谓词的 lambda 表达式的参数设定为 string 类型即可。
贪心场景
整个题选用优先队列存储各个数据,最后将其逐个 pop() 得到的对象追加在结果字符串中,这即是贪心策略的最明显体现。
代码示例
class Solution {
public:
string largestNumber(vector<int>& nums) {
auto comp = [&](const string& s1, const string& s2)
{
return s1 + s2 < s2 + s1;
};
priority_queue<std::string, vector<string>, decltype(comp)> pq(comp);
for (auto e : nums) {
pq.push(to_string(e));
}
std::string result;
for (; !pq.empty();) {
result += pq.top();
pq.pop();
}
if(result[0] == '0') { return "0"; }
return result;
}
};
提交结果:
本文原文来自CSDN
热门推荐
戒烟限酒,告别红细胞“爆表”
天坛:世界最大祭天建筑群凝结“天人合一”哲学
北京中轴线申遗成功,天坛再获世界遗产殊荣
掌握这5个技巧,让你的手机文案轻松爆红
京师筑心app:学生心理健康的专业守护者
叶罗丽白光莹契约再升级?
胡乐老街PK松阳明清古街:谁更能代表中国文化?
中午祝福语,让你的友情升温
甲流疫苗研究获重大突破:单分子mRNA实现80%保护率
从包装到价格:全方位辨别Blackmores孕妇黄金素真伪
甲流疫情持续上升,专家建议:接种疫苗、戴口罩,安全过春节
东方医院研发“基座引擎”平台,大数据赋能甲流防控
孕期叶酸补充全攻略:最佳服用时间及搭配指南
广州天使儿童医院教你科学育儿
婴儿期发育关键点,新手爸妈必看!
儿童生长发育里程碑:从新生儿到学龄前的关键指标
红烧猪蹄制作全攻略:从食材选购到出锅装盘
凤凰古城打卡圣地:土家吊脚楼
凤凰古城必打卡:虹桥与沱江泛舟
凤凰古城晋升5A,打卡沈从文故居
天坛:圜丘祈年巧夺天工,回音壁现声学奇迹
过年饮食指南:营养师推荐的四个实用建议
冬至祭天:明清皇帝的天人对话与国运祈福仪式
天坛公园最新游玩攻略:预约购票、路线交通全解析
天坛:明清皇家祭坛,天圆地方的建筑艺术瑰宝
中年姐妹情:如何维系亲情纽带?
蚌埠市叛逆学校:用专业心理辅导点亮孩子的心灵
安徽蚌埠纽特叛逆学校:用爱与专业守护叛逆青少年
蚌埠叛逆学校:从问题少年到阳光学子的蜕变之路
猎马逊励志学校:蚌埠市叛逆学校管理模式揭秘