成都网站建设设计

将想法与焦点和您一起共享

函数拓展练习python 函数的扩展

python(15):函数(2)

===============================

为芗城等地区用户提供了全套网页设计制作服务,及芗城网站建设行业解决方案。主营业务为成都做网站、成都网站制作、芗城网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

函数并非总是直接显示输出,相反,它可以处理一些数据,并返回一个或一组值。函数返回的值被称为返回值。在函数中,可

使用return语句将值返回到调用函数的代码行

有时候,需要让实参变成可选的,这样使用函数的人就只需要在必要时才提供额外的信息,可以使用默认值来让实参变成可选的。

例如,假设要拓展函数get_formstted_name(),使其还处理中间名,为此,可将其修改类似于下面这样

python小练习:带循环和条件判断的用户输入。使用raw_input()函数来提示用户输入一个1

num = int(raw_input("Please input your number:"))

while not 0num100:

print "Please input a num between 1 and 100!"

num = int(raw_input("Please input your number:"))

else:

print num

python怎么做数学函数题

【相关学习推荐:python教程】

python做数学函数题的方法:

1、打开CMD命令行以后我们先来看一个求平方的函数,如下图所示,用pow即可计算某个数的几次方

2、接下来我们可以运用abs函数来求某一个数的绝对值,如下图所示

3、在遇到小数的时候,我们经常需要舍弃小数的部分直接用整数,那么就可以用floor函数了,但是直接用的话是报错的,如下图所示

4、这个时候我们需要导入math模块,因为floor函数在math模块中,如下图所示

5、接下来我们还会用到math函数中的开平方根的函数sqrt,如下图所示

6、最后我们在应用数学函数的时候可以直接将起赋值给某个变量,然后直接调用该变量即可,如下图所示

python练习,不能使用find函数,命令中至少构建3个函数,要求python2.7

没用到三个函数,但功能有了

def check(input_str, guess_char, secret):

length = len(input_str)

flag = False

for i in range(length):

if guess_char == input_str[i]:

secret[i] = input_str[i]

flag = True

return flag

def main():

while (True):

input_str = raw_input("Enter the secret word(all in lowercase): ")

print "======================================="

secret = ['*' for i in range(len(input_str))]

count = 0

while '*' in secret:

count += 1

print 'Word so far: ', ''.join(secret)

guess_char = raw_input("Take guess number " + str(count) + ": ")

if check(input_str, guess_char, secret):

print 'Got it! '

else:

print 'Sorry. '

print

print "Congratulations! You correctly guessed the word: ", input_str, "\n"

again = raw_input("Do you want to play one more time? y/n? ")

print

if again == "n":

break

else:

continue

if __name__ == "__main__":

main()

Python 函数进阶-高阶函数

高阶函数就是能够把函数当成参数传递的函数就是高阶函数,换句话说如果一个函数的参数是函数,那么这个函数就是一个高阶函数。

高阶函数可以是你使用 def 关键字自定义的函数,也有Python系统自带的内置高阶函数。

我们下面的例子中,函数 senior 的参数中有一个是函数,那么senior就是一个高阶函数;函数 tenfold 的参数不是函数,所以tenfold就只是一个普通的函数。

function:函数,可以是 自定义函数 或者是 内置函数;

iterable:可迭代对象,可迭代性数据。(容器类型数据和类容器类型数据、range对象、迭代器)

把可迭代对象中的数据一个一个拿出来,然后放在到指定的函数中做处理,将处理之后的结果依次放入迭代器中,最后返回这个迭代器。

将列表中的元素转成整型类型,然后返回出来。

列表中的每一个数依次乘 2的下标索引+1 次方。使用自定义的函数,配合实现功能。

参数的意义和map函数一样

filter用于过滤数据,将可迭代对象中的数据一个一个的放入函数中进行处理,如果函数返回值为真,将数据保留;反之不保留,最好返回迭代器。

保留容器中的偶数

参数含义与map、filter一致。

计算数据,将可迭代对象的中的前两个值放在函数中做出运算,得出结果在和第三个值放在函数中运算得出结果,以此类推,直到所有的结果运算完毕,返回最终的结果。

根据功能我们就应该直到,reduce中的函数需要可以接收两个参数才可以。

将列表中的数据元素组合成为一个数,

iterable:可迭代对象;

key:指定函数,默认为空;

reverse:排序的方法,默认为False,意为升序;

如果没有指定函数,就单纯的将数据安札ASCII进行排序;如果指定了函数,就将数据放入函数中进行运算,根据数据的结果进行排序,返回新的数据,不会改变原有的数据。

注意,如果指定了函数,排序之后是根据数据的结果对原数据进行排序,而不是排序计算之后的就结果数据。

将列表中的数据进行排序。

还有一点就是 sorted 函数可以将数据放入函数中进行处理,然后根据结果进行排序。

既然有了列表的内置函数sort,为什么我们还要使用sorted函数呢?

高阶函数就是将函数作为参数的函数。

文章来自

20201014-python高级函数作业

1、定义一个使用不定长参数的函数,并在函数中打印出参数及其类型,统计传入参数的个数

def test(a,b,*args,c=10,**kwargs):   

print("a=",a)

print("b=",b)

print("args=",args)

print("c=",c)

print("kwargs=",kwargs)

print("参数总长度:",1+1+len(args)+1+len(kwargs))

test(1,2,3,4,5,m=4)

def test(a,b,c=10,*args,**kwargs):    

print("a=",a)

print("b=",b)

print("args=",args)

print("c=",c)

print("kwargs=",kwargs)

print("参数总长度:",1+1+len(args)+1+len(kwargs))

test(1,2,3,4,5,m=4)

2、定义一个函数max,接受的参数类型是数值,最终返回两个数中的最大值

def max(num1,num2):

if num1num2:

return num1

else:

return num2

3、定义一个函数min,接受的参数类型是数值,最终返回两个数中的最小值

def min(num1,num2):

if num1num2:

return num1

else:

return num2

4、分别定义加减乘除四个函数实现两个数之间的加减乘除操作

# 加法

def add(a,b):

return a+b

# 减法

def sub(a,b):

return a-b

# 乘法

def mul(a,b):

return a*b

# 除法

def div(a,b):

if b==0:

return 0

else:

return a/b

5、分别定义加减乘除四个函数,然后实现多个数之间的累加累减累除累乘操作,如[1,2,3,4,5],累加即是1+2+3+4+5,注意当使用除法时,应判断被除数不能为0

#累加

def add(a,b,*args):

s=a+b

for i in args:

s=s+i

return s

#累减

def sub(a,b,*args):

s=a-b

for i in args:

s=s-i

return s

#累乘

def mul(a,b,*args):

s=a*b

for i in args:

s=s*i

return s

#累除

def div(a,b,*args):

if b==0:

return a

else:

s=a/b

for i in args:

if i ==0:

continue

else:

s=a/b

return s

6、使用不定长参数定义一个函数max_min,接受的参数类型是数值,最终返回这些数中的最大值和最小值——错题

def max_min(*args):

max=0

min=0

if len(args)==0:

return 0,0

elif len(args)==1:

return args[0],args[0]

else:

max=args[0]

min=args[0]

for i in args:

if maxi:

max=i

if mini:

min=i

return max,min

7、定义一个函数,返回n的阶乘的最后结果,并打印出如5阶乘"5!=120”的效果——错题

def f(n):

s=1

for i in range(n):

s=s*(i+1)

print('%s!=%s' %(n,s)) 

f(5)

8、定义一个函数,返回由n(包含n)以内的奇数或者偶数组成的列表,默认返回全是奇数的列表

def f(n,type='j'):

ls=[]

if type=='j':

for i in range(1,n+1):

if i%2==1:

ls.append(i)

if type=='o':

for i in range(1,n+1):

if i%2==0:

ls.append(i)

return ls

9、定义一个函数,打印出n以内的所有的素数(指在大于1的自然数中,除了1和它本身以外不再有其他因数的自然数。)——错题

def f(n):

ls=[2]

for i in range(3,n):

for j in range(2,i):

if i%j == 0:

break

else:

ls.append(i)

print(ls)

10、定义一个函数,接受三个参数,分别为字符串s、数值a1、数值a2,将字符串s从下标a1开始的a2个字符删除,并把结果返回,a2默认值为0——错题

def cut_str(s,a1,a2=0):

length = len(s)

if a1+1length or a2 == 0:

return s

else:

s1 = s[:a1]

s2 = s[a1+a2:]

return s1+s2

print(cut_str("hello",6,1))

11、请定义两个函数,一个函数画正方形,一个函数画三角形,并且可以从键盘输入值来决定画正方形还是画三角形以及决定是否退出程序

我的答案:

import turtle

def z():

for i in range(4):

turtle.fd(20)

turtle.right(90)

def s():

for i in range(3):

turtle.fd(20)

turtle.right(120)

m=input('请输入值,z画正方形,s画三角形,其它任意键退出程序:')

if m =='z':

z()

elif m=='s':

s()

else:

print('退出程序')

官方答案:

def square(n):

for i in range(n):

print("*"*n)

def triangle(n):

for i in range(n):

print("*"*(i+1))

12、定义函数findall,实现对字符串find方法的进一步封装,要求返回符合要求的所有位置的起始下标,如字符串"helloworldhellopythonhelloc++hellojava",需要找出里面所有的"hello"的位置,最后将返回一个元组(0,10,21,29),即将h的下标全部返回出来,而find方法只能返回第一个——没懂

def findall(string, s):

ret = []

if s=='':

return ret

while True:

index = string.find(s)

if index != -1:

if len(ret)!=0:

ret.append(ret[-1]+index+len(s))

else:

ret.append(index)

string = string[index+len(s):]

else:

break

return ret

print(findall("abc-abc-abc-","-"))


网站标题:函数拓展练习python 函数的扩展
本文路径:http://chengdu.cdxwcx.cn/article/hphddi.html