【代码随想录算法训练营——Day28】贪心算法——134.加油站、135.分发糖果、860.柠檬水找零、406.根据身高重建队列

LeetCode题目链接

https://leetcode.cn/problems/gas-station/description/

https://leetcode.cn/problems/candy/description/

https://leetcode.cn/problems/lemonade-change/description/

https://leetcode.cn/problems/queue-reconstruction-by-height/description/

题解
134.加油站

暴力写法通过了,我就掌握暴力写法吧。题目可能还没看懂。暴力解法也要注意索引值以及对于题目解释案例的变通之处。比如计算rest的方法。

135.分发糖果

思路还记得,就记得要从前向后和从后向前两种遍历方式,但糖果的加法完全忘了,其实两种遍历分别是两种不同的解法,尤其是第二种。

860.柠檬水找零

记得思路,基本上写的和题解是一样的。

406.根据身高重建队列

考虑两个维度,一定要先确定好一个维度再看下一个维度。

代码里注意sort的写法,空vector插入的写法,两个语法问题。(保证一定是从位置0开始插入?)

代码

cpp 复制代码
//134.加油站
cpp 复制代码
//135.分发糖果
cpp 复制代码
//860.柠檬水找零
#include <iostream>
#include <vector>
#include <map>
using namespace std;

class Solution {
public:
    bool lemonadeChange(vector<int>& bills) {
		map<int, int> mp;
		for (int i = 0;i < bills.size();i++) {
			if (bills[i] == 5) {
				mp[5]++;
			}
			else if (bills[i] == 10) {
				mp[10]++;
				mp[5]--;
				if (mp[5] < 0) return false;
			}
			else {
				if (mp[10] > 0 && mp[5] > 0) {
					mp[20]++;
					mp[10]--;
					mp[5]--;
				}
				else if (mp[5] >= 3) {
					mp[20]++;
					mp[5] -= 3;
				}
				else {
					return false;
				}
			}
		}
		return true;
    }
};

int main() {
	Solution s;
	vector<int> nums1 = { 5,5,5,10,20 }, nums2 = { 5,5,10,10,20 };
	printf("%d", s.lemonadeChange(nums2));
	return 0;
}
cpp 复制代码
//406.根据身高重建队列
相关推荐
全糖可乐气泡水11 小时前
Codex适配国产信创环境安装部署与技术适配全解析
开发语言·git·python·算法·百度
h_a_o777oah11 小时前
状态机+划分型 DP :深度解析K-划分问题下 DP 状态的转移逻辑(洛谷P2679 P2331 附C++代码)
c++·算法·动态规划·acm·状态机dp·划分型dp·滚动数组优化
05候补工程师11 小时前
从算法理想向工程现实的跨越:SLAM 核心架构、思维误区与 Nav2 实战避坑指南
人工智能·算法·安全·架构·机器人
手写码匠12 小时前
Android 17 适配实战指南:新特性解读、隐私变更与迁移全攻略
人工智能·深度学习·算法·aigc
珊瑚里的鱼13 小时前
leetcode42雨水
算法·leetcode
水木流年追梦13 小时前
大模型入门-大模型的推理策略
开发语言·python·算法·正则表达式·prompt
生成论实验室13 小时前
用事件关系网络重新理解AI(三):激活函数、微调与元学习
人工智能·学习·算法·语言模型·可信计算技术
Narv工程师13 小时前
嵌入式机器人控制器算力评估:从DMIPS到WCET的完整指南
人工智能·算法·机器学习
蒟蒻的贤13 小时前
实训1227
算法
liulilittle13 小时前
TCP UCP:基于卡尔曼滤波的BBR增强型拥塞控制算法
linux·网络·c++·tcp/ip·算法·c·通讯