leetcode Python編碼練習

2021-10-07 01:13:50 字數 695 閱讀 6764

貪心演算法:

1.環形路上有n個加油站,第i個加油站的汽油量是gas[i].

你有一輛車,車的油箱可以無限裝汽油。從加油站i走到下乙個加油站(i+1)花費的油量是cost[i],你從乙個加油站出發,剛開始      的時候油箱裡面沒有汽油。

求從哪個加油站出發可以在環形路上走一圈。返回加油站的下標,如果沒有答案的話返回-1。

思路:剩餘油量gis[i]-cos[i],如果大於等於0,終點就往後移,直到最後終點又跑到了起點的位置;如果小於0,起點往前移

# @param gas int整型一維陣列 

# @param cost int整型一維陣列

# @return int整型

#class solution:

def cancompletecircuit(self , gas , cost ):

start = len(gas)-1

end = 0

sum = gas[start]-cost[start]

while end=0:

sum += gas[end]-cost[end]

end +=1

else:

start -=1

sum += gas[start]-cost[start]

return -1 if sum<0 else start

LeetCode Python 打家劫舍I

你是乙個專業的小偷,計畫偷竊沿街的房屋。每間房內都藏有一定的現金,影響你偷竊的唯一制約因素就是相鄰的房屋裝有相互連通的防盜系統,如果兩間相鄰的房屋在同一晚上被小偷闖入,系統會自動報警。給定乙個代表每個房屋存放金額的非負整數陣列,計算你在不觸動警報裝置的情況下,能夠偷竊到的最高金額。示例 1 輸入 1...

leetcode Python實現 70 爬樓梯

描述 假設你正在爬樓梯。需要 n 步你才能到達樓頂。每次你可以爬 1 或 2 個台階。你有多少種不同的方法可以爬到樓頂呢?注意 給定 n 是乙個正整數。示例1 輸入 2 輸出 2 解釋 有兩種方法可以爬到樓頂。1.1 步 1 步 2.2 步 示例2 輸入 3 輸出 3 解釋 有三種方法可以爬到樓頂。...

兩數相加 leetcode Python

給定兩個非空鍊錶來表示兩個非負整數。位數按照逆序方式儲存,它們的每個節點只儲存單個數字。將兩數相加返回乙個新的鍊錶。你可以假設除了數字 0 之外,這兩個數字都不會以零開頭。示例 輸入 2 4 3 5 6 4 輸出 7 0 8 原因 342 465 807 definition for singly ...