算法训练营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 小时前
5G上行DCI字段判定:端口 流数 PMI选择详解
java·算法·5g
xieliyu.4 小时前
Java算法精讲:双指针(二)
java·开发语言·算法
wayz115 小时前
Momentum:PSL(心理线指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
8Qi86 小时前
LeetCode 213:打家劫舍 II(House Robber II)—— 题解 ✅
算法·leetcode·职场和发展·动态规划
三品吉他手会点灯6 小时前
C语言学习笔记 - 44.运算符和表达式 - 运算符2 - 除法与取余运算符
c语言·开发语言·笔记·算法
乐迪信息6 小时前
乐迪信息:AI算法盒子实时识别船舶烟雾与火焰异常
大数据·人工智能·算法·安全·目标跟踪
J-Tony116 小时前
【JVM】根可达算法
jvm·算法
艾iYYY6 小时前
string 类的模拟实现
android·服务器·c语言·c++·算法
Lsk_Smion7 小时前
力扣实训 _ [75].颜色分类 _ 杨辉三角
数据结构·算法·leetcode