Leetcode刷题——二进制求和、x的平方根、爬楼梯
1,二进制求和
给你两个二进制字符串 a 和 b ,以二进制字符串的形式返回它们的和。
示例 1:
输入:a = “11”, b = “1”
输出:“100”
示例 2:
输入:a = “1010”, b = “1011”
输出:“10101”
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/add-binary
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
class Solution:
def addBinary(self, a: str, b: str) -> str:
carry=0
ans=[]
n=max(len(a),len(b))
for i in range(n):
if i<len(a):
carry+=int(a[len(a)-i-1])
else:
carry+=0
if i<len(b):
carry+=int(b[len(b)-i-1])
else:
carry+=0
ans.append(carry % 2) //记录同位置的值
carry//=2 //记录进位
if carry==1:
ans.append(1)
ans.reverse()
result = ""
for i in ans:
result += str(i)
return result
2,x 的平方根
给你一个非负整数 x ,计算并返回 x 的 算术平方根 。
由于返回类型是整数,结果只保留 整数部分 ,小数部分将被 舍去 。
注意:不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5 。
示例 1:
输入:x = 4
输出:2
示例 2:
输入:x = 8
输出:2
解释:8 的算术平方根是 2.82842…, 由于返回类型是整数,小数部分将被舍去。
// 二分法
class Solution:
def mySqrt(self, x: int) -> int:
l=0
r=x
ans=0
while(l<=r):
mid=l+(r-l)//2
if mid*mid<=x:
ans=mid
l=mid+1
else:
r=mid-1
return ans
3,爬楼梯
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?
示例 1:
输入:n = 2
输出:2
解释:有两种方法可以爬到楼顶。
- 1 阶 + 1 阶
- 2 阶
示例 2:
输入:n = 3
输出:3
解释:有三种方法可以爬到楼顶。
4. 1 阶 + 1 阶 + 1 阶
5. 1 阶 + 2 阶
6. 2 阶 + 1 阶
// An highlighted block
class Solution:
def climbStairs(self, n: int) -> int:
list= [0]*(n+1) //先开辟n+1长度的list
list[0]=1
list[1]=1
for i in range(2,n+1):
list[i]=list[i-1]+list[i-2] //递归
return list[n]