No. 1
经典的动态规划入门题目——跳台阶问题,连续提交三四次没有通过,记录一下教训。
【跳台阶】
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?
注意:给定 n 是一个正整数。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/climbing-stairs
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
提交问题代码:
class Solution: def climbStairs(self, n: int) -> int: dp = [i for i in range(n+1)] i = 2 while i > 2 and i < n: dp[i] = dp[i-1] + dp[i-2] return dp[n]
前两个元素 dp[1]=1 dp[2] = 2
因此初始化为 dp[i] = i
问题有三:
1. while i > 2 and i < n:
while 从3开始递归,i 初始化为了1,while代码根本不会执行
2. while 体代码每次执行完, i 没有给出更新式 i += 1, while内代码根本不会迭代
3. while 循环终止条件为: i<n
则 只会求出dp[i-1],
(Over)
No. 2
写了这么多天算法,第一次知道原来在类中要使用自定义函数,函数必须在使用前定义好,而不能在之后!!
难道self.function可以不用管吗,试验一下:
class Solution: def Power(self, base, exponent): # write code here if base > -0.00001 and base < 0.00001: return 0.0 if exponent == 0: return 1.0 max_ex = max(exponent, 0-exponent) if exponent>0: return self.powerunsighnormal(base, max_ex) else: return 1 / self.powerunsighnormal(base, max_ex) def powerunsighnormal(self, base, ex): if ex == 1: return base elif ex % 2 == 0: return self.powerunsighnormal(base, ex//2) ** 2 else: return (self.powerunsighnormal(base, ex//2) ** 2) * base
果然和我猜测的一样, 定义self打头的函数,可以放在使用函数的后面!!!(难道是编译器会先读一边self函数?)
注意: self函数定义时必须第一个参数为self,
调用self函数时必须以self打头书写!!!