算法训练营day30,贪心算法4

import "sort"

// 860. 柠檬水找零

func lemonadeChange(bills []int) bool {

//如果最开始就大于5元,肯定无法找零直接返回false

if len(bills) > 0 && bills[0] > 5 {

return false

}

five := 0

ten := 0

twenty := 0

for i := 0; i < len(bills); i++ {

//等于5元直接收下不用找零,five++

if bills[i] == 5 {

five++

//如果是10元,且有5元可以找零

} else if bills[i] == 10 && five > 0 {

ten++

five--

} else if bills[i] == 20 && five > 0 {

//如果是20元,可以找10元+5元或者3个五元,优先采用10+5方式

if ten > 0 {

twenty++

ten--

five--

} else {

if five < 3 {

return false

}

five -= 3

}

//如果没有五元找零,直接返回false

} else if five == 0 && (bills[i] == 10 || bills[i] == 20) {

return false

}

}

return true

}

//406. 根据身高重建队列

func reconstructQueue(people [][]int) [][]int {

sort.Slice(people, func(i, j int) bool {

if people[i][0] == people[j][0] { //如果身高相等则按照k从小到大排序

return people[i][1] < people[j][1]

}

return people[i][0] > people[j][0] //身高由大到小排序

})

// 再按照K进行插入排序,优先插入K小的

for i := 0; i < len(people); i++ {

p := people[i]

copy(people[p[1]+1:i+1], people[p[1]:i+1])

people[p[1]] = p

}

return people

}

//452. 用最少数量的箭引爆气球

func findMinArrowShots(points [][]int) int {

if len(points) == 0 {

return 0

}

arrow := 1 //弓箭数量

//按第一位从小到大排序

sort.Slice(points, func(i, j int) bool {

return points[i][0] < points[j][0]

})

for i := 1; i < len(points); i++ {

//如果前一个右边界比当前左边界小说明无法一起射破,需要增加一支箭

if points[i-1][1] < points[i][0] {

arrow++

} else {

// 如果当前边界比之前边界大,则沿用之前边界

if points[i][1] > points[i-1][1] {

points[i][1] = points[i-1][1]

}

}

}

return arrow

}

相关推荐
zephyr056 分钟前
C++ STL unordered_set 与 unordered_map 完全指南
开发语言·数据结构·c++
wen__xvn10 分钟前
牛客周赛 Round 127
算法
大锦终12 分钟前
dfs解决FloodFill 算法
c++·算法·深度优先
橘颂TA24 分钟前
【剑斩OFFER】算法的暴力美学——LeetCode 200 题:岛屿数量
算法·leetcode·职场和发展
苦藤新鸡28 分钟前
14.合并区间(1,3)(2,5)=(1,5)
c++·算法·leetcode·动态规划
程序员-King.37 分钟前
day145—递归—二叉树的右视图(LeetCode-199)
算法·leetcode·二叉树·递归
漫随流水41 分钟前
leetcode算法(112.路径总和)
数据结构·算法·leetcode·二叉树
过期的秋刀鱼!1 小时前
机器学习-带正则化的成本函数-
人工智能·python·深度学习·算法·机器学习·逻辑回归
ScilogyHunter1 小时前
前馈/反馈控制是什么
算法·控制
_OP_CHEN1 小时前
【算法基础篇】(四十八)突破 IO 与数值极限:快速读写 +__int128 实战指南
c++·算法·蓝桥杯·算法竞赛·快速读写·高精度算法·acm/icpc