• 【leetcode】小白刷题之路 Day1


    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打头书写!!!

  • 相关阅读:
    PAT Advanced 1008 Elevator (20) [数学问题-简单数学]
    PAT Advanced 1051 Pop Sequence (25) [栈模拟]
    PAT Basic 完美数列(25) [two pointers]
    PAT Basic 插⼊与归并(25) [two pointers]
    PAT Advanced 1089 Insert or Merge (25) [two pointers]
    第五章 数据的共享和保护
    第四章 面向对象程序设计的基本特点 课堂笔记
    第三章 函数 课堂笔记
    扫描线-Meteor UVALive
    贪心-Stall Reservations POJ
  • 原文地址:https://www.cnblogs.com/ACStrive/p/11440014.html
Copyright © 2020-2023  润新知