zoukankan      html  css  js  c++  java
  • 第017讲:函数

    0. 你有听说过DRY吗?

      me:不知道

      参考答案:

          

    1. 都是重复一段代码,为什么我要使用函数(而不使用简单的拷贝黏贴)呢?
      me:函数可以设置参数。

      参考答案:0) 可以降低代码量(调用函数只需要一行,而拷贝黏贴需要N倍代码)
          1) 可以降低维护成本(函数只需修改def部分内容,而拷贝黏贴则需要每一处出现的地方都作修改)
          2) 使序更容易阅读(没有人会希望看到一个程序重复一万行“I love FishC.com”)
    2. 函数可以有多个参数吗?

      me:无数个,但是设置多了也不是很好,代码不容易度阅读,一般一到两个比较合适;

      参考答案:可以的,理论上你想要有多少个就可以有多少个,只不过如果函数的参数过多,在调用的时候出错的机率就会大大提高,因而写这个函数的程序员也会被相应的问候祖宗,所以,尽量精简吧,在Python的世界里,精简才是王道!
    3. 创建函数使用什么关键字,要注意什么?

      me:def创建函数,

      参考答案:使用“def”关键字,要注意函数名后边要加上小括号“()”,然后小括号后边是冒号“:”,然后缩进部分均属于函数体的内容

    4. 请问这个函数有多少个参数?

    def MyFun((x, y), (a, b)):
        return x * y - a * b

      me:4个

      参考答案:如果你回答两个,那么恭喜你错啦,答案是0,因为类似于这样的写法是错误的!
          我们分析下,函数的参数需要的是变量,而这里你试图用“元祖”的形式来传递是不可行的。

    5.请问调用以下这个函数会打印什么内容?

    def hello():
            print('Hello World!')
            return
            print('Welcome To FishC.com!')

      me:“hello,world”

      参考答案:因为当Python执行到return语句的时候,Python认为函数到此结束,需要返回了(尽管没有任何返回值)。

    动手

    0. 编写一个函数power()模拟内建函数pow(),即power(x, y)为计算并返回x的y次幂的值。

      me:

    def power(x,y):
        return x**y

    参考答案:

    def power(x, y):
        result = 1
        
        for i in range(y):
            result *= x
    
        return result
    
    print(power(2, 3))

    1. 编写一个函数,利用欧几里得算法(脑补链接)求最大公约数,例如gcd(x, y)返回值为参数x和参数y的最大公约数。

      me:

    def gcd(a, b):
        while a != 0:
            a, b = b % a, a
     
        return b

      参考答案:

    def gcd(x, y):
        while y:
            t = x % y
            x = y
            y = t
    
        return x
        
    print(gcd(4, 6))

    2.编写一个将十进制转换为二进制的函数,要求采用“除2取余”(脑补链接)的方式,结果与调用bin()一样返回字符串形式。

      me:

    def Dec2Bin(dec):
        temp = []
        result = ''
        while dec:
            quo = dec % 2
            dec = dec // 2
            temp.append(quo)
        while temp:
            result += str(temp.pop())
         
        return result
    print(Dec2Bin(62))

      参考答案:

    def Dec2Bin(dec):
        temp = []
        result = ''
        
        while dec:
            quo = dec % 2
            dec = dec // 2
            temp.append(quo)
    
        while temp:
            result += str(temp.pop())
        
        return result
    
    print(Dec2Bin(62))
  • 相关阅读:
    Lc112_路径总和
    多线程(4)
    Lc257_二叉树的所有路径
    Lc226_翻转二叉树
    Lc145_二叉树的后序遍历
    Lc144_二叉树的前序遍历
    Lc102_二叉树的层序遍历
    Lc101_对称二叉树
    Lc100_相同的树
    Lc94_二叉树的中序遍历
  • 原文地址:https://www.cnblogs.com/kugua7878445/p/11831876.html
Copyright © 2011-2022 走看看