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

}

相关推荐
黎阳之光1 小时前
黎阳之光:以视频孪生重构智能监盘,为燃机打造新一代智慧电厂大脑
大数据·人工智能·算法·安全·数字孪生
绝知此事2 小时前
【算法突围 02】树形结构与数据库索引:树形结构与数据库索引:从 BST 到 B+ 树的演化与 MySQL 优化
数据库·mysql·算法·面试·b+树
清木!2 小时前
排序算法比较
数据结构·算法·排序算法
吴可可1233 小时前
用Teigha修改并保存CAD文件
数据库·算法·c#
审判长烧鸡3 小时前
【Go Interface】接口诞生的意义
go·接口·interface
汉克老师3 小时前
GESP6级C++考试语法知识(十七、数据结构(三、认识队列 Queue))
数据结构·c++·队列·gesp6级·gesp六级·数组模拟队列
灰灰勇闯IT4 小时前
ops-reduce:ReduceMax 与 ReduceMean 的并行优化
算法
水木流年追梦4 小时前
大模型入门-Reward 奖励模型训练
开发语言·python·算法·leetcode·正则表达式
JavaWeb学起来4 小时前
Python学习教程(六)数据结构List(列表)
数据结构·python·python基础·python教程
沙威玛_LHE4 小时前
P13376题解
算法