文巾解题 881. 救生艇
生活随笔
收集整理的這篇文章主要介紹了
文巾解题 881. 救生艇
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1 題目描述
2 解題思路:貪心
?????????我們把重量從低到高排序,盡量讓最輕的人和最重的人在一艘船上。如果最輕的+最終的仍然比limit重,那么最重的人單獨一艘船
2.1 遞歸解決貪心
class Solution:def numRescueBoats(self, people: List[int], limit: int) -> int:people.sort()def f(begin,end):print(begin,end)if(begin>end):return 0if(begin==end):return 1if(people[begin]+people[end]<=limit):return 1+f(begin+1,end-1)if(people[begin]+people[end]>limit):return 1+f(begin,end-1)return(f(0,len(people)-1))2.2 雙指針解決貪心
class Solution:def numRescueBoats(self, people: List[int], limit: int) -> int:people.sort()ret=0begin=0end=len(people)-1while(begin<=end): #begin=end不用特判,因為無論如何就剩下這一個了,船的數量肯定加一,所以不用管他是在if語句還是else語句里面if(people[begin]+people[end]<=limit):begin+=1end-=1else:end-=1ret+=1return(ret)?
總結
以上是生活随笔為你收集整理的文巾解题 881. 救生艇的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: sklearn 笔记:数据归一化(Sta
- 下一篇: NTU 课程笔记:ERIC(3) 开展研