算法训练营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

}

相关推荐
地平线开发者4 小时前
profiler debug 工具用法与高一致性策略
算法·自动驾驶
编程大师哥4 小时前
匿名函数 lambda + 高阶函数
java·python·算法
我叫袁小陌5 小时前
算法解题思路指南
算法
地平线开发者5 小时前
Conv+BN+Add+ReLU 融合机制简介
算法·自动驾驶
喵个咪5 小时前
GoWind Toolkit Go后端代码生成 完整全流程实战
后端·go·orm
也曾看到过繁星5 小时前
数据结构---顺序表
数据结构
yuanyuan2o25 小时前
模型预训练:Hugging Face Transformers 基础
算法·ai·语言模型·自然语言处理·nlp·深度优先
杨充5 小时前
1.3 浮点型数据设计灵魂
开发语言·python·算法
妄想出头的工业炼药师6 小时前
GS slam mono
算法·开源