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

import "sort"

// 860. 柠檬水找零

func lemonadeChange(bills \[\]int) bool {

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

if len(bills) > 0 && bills0 > 5 {

return false

}

five := 0

ten := 0

twenty := 0

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

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

if billsi == 5 {

five++

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

} else if billsi == 10 && five > 0 {

ten++

five--

} else if billsi == 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 && (billsi == 10 || billsi == 20) {

return false

}

}

return true

}

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

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

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

if peoplei0 == peoplej0 { //如果身高相等则按照k从小到大排序

return peoplei1 < peoplej1

}

return peoplei0 > peoplej0 //身高由大到小排序

})

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

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

p := peoplei

copy(peoplep\[1+1:i+1], peoplep\[1:i+1])

peoplep\[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 pointsi0 < pointsj0

})

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

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

if pointsi-11 < pointsi0 {

arrow++

} else {

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

if pointsi1 > pointsi-11 {

pointsi1 = pointsi-11

}

}

}

return arrow

}

相关推荐
旖-旎29 分钟前
《LeetCode 130 被围绕的区域 FloodFill DFS 解法》
c++·算法·深度优先·力扣·floodfill
林森lsjs31 分钟前
斐波那契数列的 N 种解法:从递归到动态规划的优化之路【算法思考】
算法·动态规划
apcipot_rain2 小时前
计科八股20260616(1)——堆存中位数、链表判环、黑白测试、敏捷开发与瀑布模型、配置管理、持续集成、池化
数据结构·算法·软件工程
JAVA面经实录9178 小时前
Java 数据结构与算法 (终极完整学习文档)
java·数据结构·算法
开源Z10 小时前
LeetCode 42 · 接雨水:从暴力到双指针的三步优化
算法·leetcode
旖-旎10 小时前
《LeetCode 695 岛屿的最大面积 FloodFill DFS 解法》
c++·算法·力扣·深度优先遍历·floodfill
影视飓风TIM10 小时前
数据结构 | 链表超全笔记(单链表+双链表+高频算法题)
数据结构·笔记·链表
syagain_zsx10 小时前
STL 之 vector 讲练结合
c++·算法
牛油果子哥q11 小时前
STL set与map底层精讲,红黑树适配原理、有序去重特性、迭代器遍历、API实战与面试核心考点全解
开发语言·数据结构·c++·面试