python函数结构答案 数据结构与算法python语言描述答案

python求答案

第一题:int

十多年的莲花网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。营销型网站建设的优势是能够根据用户设备显示端的尺寸不同,自动调整莲花建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联从事“莲花网站设计”,“莲花网站推广”以来,每个客户项目都认真落实执行。

第二题:-1

第三题:list

第四题:key in dict

第五题:false

第六题:return

第七题:开源

第八题:

第九题:dict.get(key)

第十题:(1)无参数,无返回值;(2)无参数,有返回值的函数;(3)有参数,无返回值的函数;(4)有参数,有返回值的函数

Python其实很简单 第十二章 函数与变量的作用域

在前面已经多次提到函数这个概念,之所以没有解释什么是函数,是因为程序中的函数和数学中的函数差不多,如input()、range()等都是函数,这些都是Python的标准函数,直接使用就可以了。根据需要,用户也可以自定义函数。

12.1 函数

函数的结构:

def 函数名(参数):

函数体

return 返回值

例如:数学中的函数f(x)=2x+5在Python中可以定义如下:

def f(x):

y=2*x+5

return(y)

如果x取值为3,可以使用如下语句调用函数:

f(3)

下面给出完整的程序代码:

def f(x):

y=2*x+5

return(y)

res=f(3)

print(res)

运行结果:11

如上例中的x是函数f(x)的参数,有时也被称为形式参数(简称形参),在函数被调用时,x被具体的值3替换y就是函数的返回值,这个值3也被称为实际参数(简称实参)。

上例中的y是函数f(x)的返回值。并不是所有的函数都有参数和返回值。如下面的函数:

def func():

print('此为无参数传递、无返回值的函数')

func()

输出结果:此为无参数传递、无返回值的函数

可以看出,该函数func()无参数,故调用时不用赋给参数值。

函数也可以有多个参数,如f(x,y)=x²+y²,可用Python语言定义如下:

def f(x,y):

z=x**2+y**2

return z

print(f(2,3)) #调用函数f(x,y)

输出结果:13

也可以通过直接给参数列表中的参数赋值的方法,为参数添加默认值,如果用户赋予参数值,则按照用户赋值执行,否则使用默认值。例如:

def f(x,y=3):

z=x**2+y**2

return z

若调用时参数列表为(2,1),即x赋值为2,y赋值为1:

print(f(2,1))

输出结果为:5

若调用时参数列表为(2),即x赋值为2,y赋值省缺,则y使用默认值:

print(f(2))

输出结果为:13

回调函数,又称函数回调,是将函数作为另一函数的参数。

例如:

def func(fun,m,n):

fun(m,n)

def f_add(m,n):

print('m+n=',m+n)

def f_mult(m,n):

print('m*n=',m*n)

func(f_add,2,3)

func(f_mult,2,3)

输出结果:

m+n= 5

m*n= 6

在f_add(m,n)和f_mult(m,n)被定义前,func(fun,m,n)中的fun(m,n)就已经调用了这两个函数,即“先调用后定义”,这也是回调函数的特点。

如果无法预知参数的个数,可以在参数前面加上*号,这种参数实际上对应元组类型。譬如,参会的人数事先不能确定,只能根据与会人员名单输入:

def func(*names):

print('今天与会人员有:')

for name in names:

print(name)

func('张小兵','陈晓梅','李大海','王长江')

运行后,输出结果为:

今天与会人员有:

张小兵

陈晓梅

李大海

王长江

参数为字典类型,需要在参数前面加上**号。

def func(**kwargs):

for i in kwargs:

print(i,kwargs[i])

func(a='a1',b='b1',c='c1')

输出结果为:

a a1

b b1

c c1

一个有趣的实例:

def func(x,y,z,*args,**kwargs):

print(x,y,z)

print(args)

print(kwargs)

func('a','b','c','Python','is easy',py='python',j='java',ph='php')

输出结果:

a b c # 前三个实参赋给前三个形参

('Python', 'is easy') # *args接收元组数据

{'py': 'python', 'j': 'java', 'ph': 'php'} # **kwargs接收字典数据

12.2 变量的作用域

变量的作用域即变量的有效范围,可分为全局变量和局部变量。

局部变量

在函数中定义的变量就是局部变量,局部变量的作用域仅限于函数内部使用。

全局变量

在主程序中定义的变量就是全局变量,但在函数中用关键字global修饰的变量也可以当做全局变量来使用。

全局变量的作用域是整个程序,也就是说,全局变量可以在整个程序中可以访问。

下面通过实例去讨论:

程序1:

a=1 # a为全局变量

def a_add():

print('a的初值:',a) # 在函数中读取a的值

a_add() # 调用函数a_add()

a+=1 # 主程序语句,a增加1

print('a现在的值是:',a) # 主程序语句,读取a的值

运行结果:

a的初值: 1

a现在的值是: 2

这个结果和我们想象的一样,全局变量a既可以在主程序中读取,也可以在子程序(函数)中读取。

程序2:

a=1

def a_add():

a+=1

print('a的初值:',a)

a_add()

print('a现在的值是:',a)

运行程序1时出现如下错误提示:

UnboundLocalError: local variable 'a' referenced before assignment

意思是:局部变量'a'在赋值之前被引用。

从语法上来讲,该程序没有错误。首先定义了一个全局变量a并赋值为1,又定义了一个函数a_add(),函数内的语句a+=1就是出错的根源,虽然我们的初衷是想让全局变量a的值增加1,但从错误提示看,这个语句中的a并不是全局变量,而是局部变量。看来,在函数中读取全局变量的值是没有问题的(在程序1中已经得到了验证),但要在函数中改变全局变量的值是不行的(在程序2的错误提示a+=1中的a 是局部变量,而非全局变量)。

怎样解决这个问题?

程序3:

a=1

def a_add(x):

x+=1

return x

print('a的初值:',a)

a=a_add(a)

print('a现在的值是:',a)

运行结果:

a的初值: 1

a现在的值是: 2

结果的确是正确的,但在函数a_add(x)中没有调用变量a(没有出现变量a)。

程序4:

a=1

def a_add(a):

a+=1

return a

print('a的初值:',a)

a=a_add(a)

print('a现在的值是:',a)

运行结果:

a的初值: 1

a现在的值是: 2

对比程序4和程序3不难发现,其实程序4只是简单的把函数的参数x变成了a,这个a的实质和程序3中的x还是一样的。这进一步证实,函数中的a是局部变量,与主程序的全局变量a有着本质的区别。

程序5:

a=1

def a_add():

global a

a+=1

print('a的初值:',a)

a_add()

print('a现在的值是:',a)

运行结果:

a的初值: 1

a现在的值是: 2

程序5和程序2相比较,仅仅是在函数中添加了一个定义“global a”,此时的局部变量a就可以当做全局变量使用,由于它和全局变量a同名,自然也就不用区分a究竟是全局变量还是局部变量了,在主程序和该函数内都可以访问、修改变量a的值了。

虽然使用global可使变量使用起来非常方便,但也容易引起混淆,故在使用过程中还是谨慎为好。

12.3 函数的递归与嵌套

递归,就是函数调用它自身。递归必须设置停止条件,否则函数将无法终止,形成死循环。

以计算阶乘为例:

def func(n):

if n==1:

return 1

else:

return n*func(n-1) #func( )调用func( )

print(func(5))

运行结果为:120

嵌套,指在函数中调用另外的函数。这是程序中常见的一种结构,在此不再赘述。

匿名函数

Python中可以在参数前加上关键字lambda定义一个匿名函数,这样的函数一般都属于“一次性”的。

例如:

程序1:这是一个常规的函数定义和调用。

def f_add(x,y):

return x+y

print(f_add(2,3))

输出结果:5

程序2:使用lambda定义匿名函数。

f_add=lambda x,y:x+y

print(f_add(2,3))

输出结果:5

从上面的代码可以看出,使用lambda仅仅减少了一行代码。f_add=lambda x,y:x+y中的f_add不是变量名,而是函数名。程序1和程序2的print( )语句中的参数都是一样的——调用函数f_add( )。所以,匿名函数并没有太多的优点。

python函数问题

Python函数:

函数是组织好的,可重复使用的,用来实现单一或相关联功能的代码段。

函数能提高应用的模块性,和代码的重复利用率。已经知道Python提供了许多内建函数,比如print()。但也可以自己创建函数,这被叫做用户自定义函数。

函数调用:

定义一个函数只给了函数一个名称,指定了函数里包含的参数,和代码块结构。

这个函数的基本结构完成以后,可以通过另一个函数调用执行,也可以直接从Python提示符执行。

40道python二级考试真题火爆互联网,完整版答案解析为你保驾护航

1.以下关于程序设计语言的描述,错误的选项是:

A Python语言是一种脚本编程语言

B 汇编语言是直接操作计算机硬件的编程语言

C 程序设计语言经历了机器语言、汇编语言、脚本语言三个阶段

D 编译和解释的区别是一次性翻译程序还是每次执行时都要翻译程序

正确答案: C

2.表达式 1001 == 0x3e7 的结果是:

A false

B False

C true

D True

正确答案: B

3.以下选项,不是Python保留字的选项是:

A del

B pass

C not

D string

正确答案: D

4.表达式 eval(‘500/10’) 的结果是:

A ‘500/10’

B 500/10

C 50

D 50.0

正确答案: D

5.表达式 type(eval(‘45’)) 的结果是:

A

B

C None

D

正确答案: D

6.表达式 pmod(20,3) 的结果是:

A 6, 2

B 6

C 2

D (6, 2)

正确答案: D

7.以下关于字符串类型的操作的描述,错误的是:

A str.replace(x,y)方法把字符串str中所有的x子串都替换成y

B 想把一个字符串str所有的字符都大写,用str.upper()

C 想获取字符串str的长度,用字符串处理函数 str.len()

D 设 x = ’aa’ ,则执行x*3的结果是‘aaaaaa’

正确答案: C

8.设 str = ‘python’,想把字符串的第一个字母大写,其他字母还是小写,正确的选项是:

A print(str[0].upper()+str[1:])

B print(str[1].upper()+str[-1:1])

C print(str[0].upper()+str[1:-1])

D print(str[1].upper()+str[2:])

正确答案: A

9.以下选项,不属于程序流程图基本元素的是:

A 循环框

B 连接点

C 判断框

D 起始框

正确答案: A

10.以下关于循环结构的描述,错误的是:

A 遍历循环使用for in 语句,其中循环结构不能是文件

B 使用range()函数可以指定for循环的次数

C for i in range(5)表示循环5次,i的值是从0到4

D 用字符串做循环结构的时候,循环的次数是字符串的长度

正确答案: A

11.执行以下程序,输入”93python22”,输出结果是:

A python9322

B python

C 93python22

D 9322

正确答案: C

A la

B 请输入整数

C pythonpython

D python

正确答案: C

A 2

B 请输入q退出:

C 3

D 1

正确答案: A

14.以下程序的输出结果是:

A 0

B 2

C UnboundLocalError

D 5

正确答案: A

A 18 None

B 10 18

C UnboundLocalError

D 18 18

正确答案: B

def test( b = 2, a = 4):

global z

z += a * b

return z

z = 10

print(test(),z)

18,18

17.以下程序的输出结果是:

A 22.0 None

B 10 None

C 22 None

D 10.0 22.0

正确答案: B

18.以下表达式,正确定义了一个集合数据对象的是:

A x = { 200, ’flg’, 20.3}

B x = ( 200, ’flg’, 20.3)

C x = [ 200, ’flg’, 20.3 ]

D x = {‘flg’ : 20.3}

正确答案: A

19.以下程序的输出结果是:

A [‘z’, ‘j’, ‘s’, ‘y’]

B [‘j’, ‘s’, ‘y’, ‘z’]

C [‘j’, ‘z’, ‘z’, ‘s’, ‘z’, ‘y’, ‘j’]

D [‘j’, ‘j’, ‘s’, ‘y’, ‘z’, ‘z’, ‘z’]

正确答案: B

20.以下程序的输出结果是:

A htslbht

B hlbst

C tsblh

D hhlstt

正确答案: B

21.已知id(ls1) = 4404896968,以下程序的输出结果是:

A 4404896968 4404896904

B 4404896904 4404896968

C 4404896968 4404896968

D 4404896904 4404896904

正确答案: A

A [‘300’,‘200’,‘400’]

B [‘shandong’, ‘hebei’, ‘beijing’]

C [300,200,400]

D ‘shandong’, ‘hebei’, ‘beijing’

正确答案: B

23.以下关于文件的描述,错误的是:

A 二进制文件和文本文件的操作步骤都是“打开-操作-关闭”

B open() 打开文件之后,文件的内容并没有在内存中

C open()只能打开一个已经存在的文件

D 文件读写之后,要调用close()才能确保文件被保存在磁盘中了

正确答案: C

24.以下程序输出到文件text.csv里的结果是:

A [90,87,93]

B 90,87,93

C ‘[90,87,93]’

D ‘90,87,93’

正确答案: B

25.以下程序的输出结果是:

A ( [1,2,3,4,5])

B [12, 34, 56, 78]

C ([12, 34, 56, 78])

D [1,2,3,4,5]

正确答案: B

26.以下关于数据维度的描述,错误的是:

A 采用列表表示一维数据,不同数据类型的元素是可以的

B JSON格式可以表示比二维数据还复杂的高维数据

C 二维数据可以看成是一维数据的组合形式

D 字典不可以表示二维以上的高维数据

正确答案: D

27.以下不属于Python的pip工具命令的选项是:

A show

B install

C download

D get

正确答案: D

29.以下不是程序输出结果的选项是:

A [12, 78, 56, 34]

B [56, 12, 78, 34]

C [12, 34, 56, 78]

D [12, 78, 34, 56]

正确答案: C

30.以下关于turtle库的描述,正确的是:

A 在import turtle之后就可以用circle()语句,来画一个圆圈

B 要用from turtle import turtle来导入所有的库函数

C home() 函数设置当前画笔位置到原点,朝向东

D seth(x) 是setheading(x)函数的别名,让画笔向前移动x

正确答案: C

31.一些重要的程序语言(如C语言和Pascal语言)允许过程的递归调用。而实现递归调用中的存储分配通常用

A 栈

B 堆

C 链表

D 数组

正确答案: A

因为函数调用是能过将关键寄存器压栈保护现场;在函数返回时,弹栈恢复现场来完成的。

而递归调用说白了就是自已调用自己。也就是不停的上演pop, push的栈操作。

系统为什么选用栈来实现函数间的调用呢?我觉的主要原因如下:

对于频繁的调用操作过程中,栈的pop,push操作最简洁,快速。硬件级(或者理解成汇编级也行)支持栈操作。所以用栈最高效,快速。如果用堆、数组、链表,不光要维护很多功能辅助性数据,算法也很麻烦。这样会大大降低计算机的使用效率。

32.下列叙述中正确的是

A 一个算法的空间复杂度大,则其时间复杂度必定小

B 一个算法的空间复杂度大,则其时间复杂度也必定大

C 算法的时间复杂度与空间复杂度没有直接关系

D 一个算法的时间复杂度大,则其空间复杂度必定小

正确答案: C

34.软件开发离不开系统环境资源的支持,其中必要的测试数据属于

A 辅助资源

B 硬件资源

C 通信资源

D 支持软件

正确答案: A

35.完全不考虑程序的内部结构和内部特征,而只是根据程序功能导出测试用例的测试方法是

A 错误推测法

B 白箱测试法

C 黑箱测试法

D 安装测试法

正确答案: C

37.下列有关数据库的描述,正确的是

A 数据库是一个关系

B 数据库是一个DBF文件

C 数据库是一个结构化的数据集合

D 数据库是一组文件

正确答案: C

38.相对于数据库系统,文件系统的主要缺陷有数据关联差、数据不一致性和

A 可重用性差

B 冗余性

C 非持久性

D 安全性差

正确答案: B

39.软件开发的结构化生命周期方法将软件生命周期划分成

A 定义、开发、运行维护

B 设计阶段、编程阶段、测试阶段

C 总体设计、详细设计、编程调试

D 需求分析、功能定义、系统设计

正确答案: A

40.下列不属于结构化分析的常用工具的是

A 判定树

B 数据字典

C 数据流图

D PAD图

正确答案: C


名称栏目:python函数结构答案 数据结构与算法python语言描述答案
URL链接:http://scjbc.cn/article/hhocge.html

其他资讯