浙大版PTA Python程序设计 题目与知识点整理(综合版)
目录
第一章
一、高级语言程序的执行方式
二、变量赋值与内存地址
三、字符编码
3.1 Unicode
3.2 ASCII(American Standard Code for Information Interchange)
四、编程语言分类按照编程范式分类
4.1 面向过程语言
4.2 面向对象语言
五、原码、反码和补码
5.1 原码
5.2 反码
5.3 补码
六、基本的计算机概念
6.1二进制和数据表示
6.2内存和存储
6.3 变量和常量
6.4运算符和表达式
6.5 控制结构
6.6 函数
6.7 数据结构
6.8 文件处理
6.9 异常处理
6.10 面向对象编程(OOP)*
6.11.模块和包
6.12 库和框架*
七、进制转换(二进制)
7.1整数部分的转换
7.2小数部分的转换
第二章
1. 数据类型和转换
1.1进制转化
1.2字符串(格式化,居中对齐)
1.3虚数类型
2. 运算和表达式
2.1取整运算
2.2四舍五入
2.3逻辑运算
2.4布尔值
2.6布尔值与比较运算
2.7布尔值与条件/循环语句
3常见错误类型 & 结果类型
3 1进制转换错误
3.2类型错误
3.3表达式结果类型
4 math 模块
5. 字符串拼接
5.1直接拼接
5.2使用加号'+'
5.3使用join()方法
5.4使用format()方法
5.5使用 f-string(格式化字符串字面量)
5.6 如果需要重复一个字符串,可以使用 * 运算符
6. 复数
7. 字符串结束标志
8. 运算注意事项
第三章
一、 判断表达式的输出:
二、 列表操作
三、随机数操作
四、列表切片
五、写法规范
六、列表拼接字符串的判断:
七、 列表操作之pop()函数:
八、 字符串处理
九、内存地址和引用
十、运算顺序: ```python
十一、打印表格内容
第四章(题目解析)
第五章 集合与字典的基本知识与应用
1.集合基本知识
1.1集合的元素 添加&删除
1.2集合的创建
1.3集合的操作
2.字典基本知识
2.1字典的键
2.2访问字典
2.3字典操作(键值对反转&字典合并)
3.数据结构总结
-3.1 创建空数据结构
- 3.2可变与不可变
4 相关题目
4.0正确数据结构选择
- 4.1输出字典中的键
- 4.2删除字典中的键值对
- 4.3输出字典中某个键的平方值
- 4.4计算字符串中单词的长度
- 4.5合并两个字典
- 4.6访问二维列表中的元素
- 4.7列表推导式
第六章 函数(题目分析)
第七章 文件和异常(题目分析)
一、判断题
二、单选题
三、填空题
第一章
一、高级语言程序的执行方式
高级语言程序要被机器执行,有以下几种常见的执行方式:
- 解释执行:通过解释器逐行解释并执行源代码。
- 编译执行:通过编译器将源代码编译成机器代码,然后由计算机执行。
- 即时编译(JIT):在运行时将部分或全部代码编译为机器代码,提高执行效率。
- 虚拟机执行:在虚拟机上运行,通过虚拟机将字节码解释或编译为机器代码。
---例题:高级语言程序要被机器执行,只有用解释器来解释执行。False
二、变量赋值与内存地址
- 变量赋值是将一个值存储到一个变量中。
- 内存地址是计算机内存中的一个位置,每个变量的值都存储在内存中的某个地址上。
- 当变量被重新赋值时,它会引用一个新的内存地址。
---例题:已知 x=3, 则执行“ x=7”后,id(x)的返回值与原来没有变化。 False
三、字符编码
3.1 Unicode
特点:
- 设计目的是覆盖世界上所有的书写系统。
- UTF-8与UTF-16使用可变长度编码,可以表示超过100万个字符。
编码形式:
- UTF-8:可变长度(1到4个字节),向后兼容ASCII,节省空间。
- UTF-16:可变长度(2或4个字节),常用于操作系统和编程语言内部。
- UTF-32:固定长度(4个字节),直接表示所有字符,但占用空间大。
示例:
- 'A' 的 UTF-8 编码是 0x41(1字节)。
- '你' 的 UTF-8 编码是 0xE4 0xBD 0xA0(3字节)。
优势:
- 能够表示几乎所有语言的字符,具有广泛的通用性。
3.2 ASCII(American Standard Code for Information Interchange)
特点:
- 使用7位二进制表示字符,最多可以表示128个(即2^7)字符。
- 包含基本的英文字母(大小写)、数字、标点符号以及一些控制字符。
示例:
- 'A' 的 ASCII 码是 65。
- 'a' 的 ASCII 码是 97。
局限性:
- 仅能表示英语及一些常见符号,不能满足其他语言的需求。
---例题:UTF-8码是不等长编码,即不同字符占用的字节数不同。True
四、编程语言分类按照编程范式分类
4.1 面向过程语言
- 特点:程序由过程(函数)构成,通过过程调用完成任务。
- 示例:C。
4.2 面向对象语言
- 特点:程序由对象构成,对象包含数据和方法,通过对象的交互完成任务。
- 示例:Java、C++、Python。
---例题:不是面向对象的程序设计语言是C。True
五、原码、反码和补码
在二进制表示中,有三种常见的编码方式:原码、反码和补码。以下是它们的定义和特点:
5.1 原码
- - 正数的原码:原码与其二进制表示相同,符号位是0。
- - 负数的原码:在二进制表示的前面加上一个1作为符号位。
5.2 反码
- - 正数的反码:反码与其原码相同。
- - 负数的反码:原码除符号位外的所有位取反。
5.3 补码
- - 正数的补码:补码与其原码相同。
- - 负数的补码:反码加1。
注意:正数的原码、反码和补码都是相同的。
---例题:十进制106的原码是___,反码是___,补码是___ (用八位表示)
解析:三个都是01101010
六、基本的计算机概念
6.1二进制和数据表示
- - 二进制(Binary):计算机使用二进制(0和1)来表示和存储数据。
- - 字节(Byte):一个字节等于8位(bit)。
- - 数据类型:包括整数、浮点数、字符串、布尔值等。不同的数据类型在内存中有不同的表示和存储方式。
- 标识符规范:由数字,字母,下划线组成;不能以数字开头;区分大小写;不能使用关键字(标识符不能是 Python 的关键字或保留字,例如
if
、for
、while
等)
6.2内存和存储
- - RAM(随机存取存储器):用于临时存储数据,断电后数据会丢失。
- - ROM(只读存储器):用于存储永久性数据,断电后数据不会丢失。
- - 存储器地址:每个存储单元都有一个唯一的地址,用于访问存储器中的数据。
6.3 变量和常量
- - 变量:用于存储可以改变的数据。
- - 常量:用于存储不变的数据。
6.4运算符和表达式
- - 算术运算符:如 `+`、`-`、`*`、`/`。
- - 比较运算符:如 `==`、`!=`、`>`、`<`。
- - 逻辑运算符:如 `and`、`or`、`not`。
6.5 控制结构
- - 条件语句:如 `if`、`elif`、`else`。
- - 循环语句:如 `for`、`while`。
6.6 函数
- -定义和调用函数:使用 `def` 关键字定义函数,通过函数名调用函数。
- - 参数和返回值:函数可以接受参数并返回值。
6.7 数据结构
- - 列表(List):有序、可变的集合,如 `[1, 2, 3]`。
- - 元组(Tuple):有序、不可变的集合,如 `(1, 2, 3)`。
- - 字典(Dictionary):键值对的集合,如 `{'key': 'value'}`。
- - 集合(Set):无序、唯一元素的集合,如 `{1, 2, 3}`。
6.8 文件处理
- - 文件读写:使用 `open` 函数打开文件,`read` 和 `write` 方法读取和写入文件。
- - 文件模式:如 `r`(读)、`w`(写)、`a`(追加)。
6.9 异常处理
- - 捕获和处理异常:使用 `try`、`except` 块来捕获和处理可能发生的异常。
6.10 面向对象编程(OOP)*
- - 类和对象:使用 `class` 关键字定义类,通过类创建对象。
- - 继承:一个类可以继承另一个类的属性和方法。
- - 封装:将数据和方法封装在类中。
- - 多态:同一方法在不同对象中的不同实现。
6.11.模块和包
- - 模块:一个Python文件就是一个模块,可以包含函数、类和变量。
- - 包:包含多个模块的文件夹,通过 `import` 关键字导入模块和包。
6.12 库和框架*
- - 标准库:Python自带的模块和包,如 `math`、`datetime`。
- - 第三方库:由社区和开发者创建的库,可以通过 `pip` 安装,如 `numpy`、`pandas`。
七、进制转换(二进制)
7.1整数部分的转换
步骤:
- 用2除十进制整数,并记录商和余数。
- 再用2除上一步的商,继续记录新的商和余数。
- 重复步骤2,直到商为0为止。
- 将所有的余数按逆序排列,即从最后一次除法得到的余数开始到第一次除法得到的余数,这些逆序排列的余数就是整数部分的二进制表示。
示例: 将十进制数 45
转换为二进制:
步骤 | 操作 | 商 | 余数 |
---|---|---|---|
1 | 45 ÷ 2 | 22 | 1 |
2 | 22 ÷ 2 | 11 | 0 |
3 | 11 ÷ 2 | 5 | 1 |
4 | 5 ÷ 2 | 2 | 1 |
5 | 2 ÷ 2 | 1 | 0 |
6 | 1 ÷ 2 | 0 | 1 |
逆序排列余数得到:101101
。
所以,45
的二进制表示为 101101
。
7.2小数部分的转换
步骤:
- 乘以2,并记录整数部分。
- 将乘以2后的结果的小数部分继续乘以2,记录新的整数部分。
- 重复步骤2,直到小数部分为0或达到所需的精度为止。
- 将所有记录的整数部分按顺序排列,即从第一次乘法得到的整数部分开始到最后一次乘法得到的整数部分,这些顺序排列的整数部分就是小数部分的二进制表示。
示例: 将十进制小数 0.625
转换为二进制:
步骤 | 操作 | 整数部分 | 小数部分 |
---|---|---|---|
1 | 0.625 × 2 = 1.25 | 1 | 0.25 |
2 | 0.25 × 2 = 0.5 | 0 | 0.5 |
3 | 0.5 × 2 = 1.0 | 1 | 0.0 |
将记录的整数部分按顺序排列得到:101
。
所以,0.625
的二进制表示为 0.101
。
---例题:十进制19.625的二进制是___(整数部分用八位二进制表示)
解析:
整数部分转换
将整数部分 19
转换为二进制:
步骤 | 操作 | 商 | 余数 |
---|---|---|---|
1 | 19 ÷ 2 | 9 | 1 |
2 | 9 ÷ 2 | 4 | 1 |
3 | 4 ÷ 2 | 2 | 0 |
4 | 2 ÷ 2 | 1 | 0 |
5 | 1 ÷ 2 | 0 | 1 |
将余数逆序排列得到:10011
。
所以,整数部分 19
的二进制表示为 10011
。
小数部分转换
将小数部分 0.625
转换为二进制:
步骤 | 操作 | 整数部分 | 小数部分 |
---|---|---|---|
1 | 0.625 × 2 = 1.25 | 1 | 0.25 |
2 | 0.25 × 2 = 0.5 | 0 | 0.5 |
3 | 0.5 × 2 = 1.0 | 1 | 0.0 |
将记录的整数部分按顺序排列得到:101
。
所以,小数部分 0.625
的二进制表示为 0.101
。
所以最后答案为 00010011.101
第二章
1. 数据类型和转换
1.1进制转化
a, b = input().split(',')
b = int(b)
c = int(a, b) # 将 b 进制的 a 转换为十进制
print(c)
# 输入 45, 8 并不会输出 37,因为 'a' 是字符串,应该改成 int(a, b) 而不是 int('a', b)
bin()#注意括号内是int类型###变成二进制
oct()#变成八进制
hex()#变成16进制hex()[2:]##加切片可以去除0b 0o 0x的前缀,其他类似
``` 例题
a,b = input().split(',')
b=int(b)
c=int('a',b) #把b进制的a变成十进制
print(c)
输入45,8并会输出37
False 因为#处第一个参数是绝对引用a字母(变成字符串了)改成int(a,b)即可输出37
1.2字符串(格式化,居中对齐)
m=int(input())
print('{:^5}'.format('*'*m))
print('{:^m}'.format('*'*m)) ###ValueError
#输入5第二个print这里不支持{:^m}在格式化指令中直接使用变量作为字段宽度或其他限制参数的值
print('{:^{width}}'.format('*'*m, width=m)) # (正确写法)输出一个宽度为 m 的居中字符串,其中 m 为输入的值
print("这是数字输出格式{:5d}".format(123)) # 输出:这是数字输出格式 123(前面有两个空格,空格表示填充)
```
1.3虚数类型
print(type(1j)) # 输出 <class 'complex'>,J 或 j 是虚数单位
注意j大小写均可 通常小写
```
2. 运算和表达式
2.1取整运算
print(type(3 // 2)) # 输出 <class 'int'>,整除运算符返回整数
```
2.2四舍五入
print(round(17.0 / 3**2, 2)) # 输出 1.89,round 函数第二个参数表示保留小数点后两位
```
2.3逻辑运算
print(0 and 1 or not 2 < True) # 输出 True,解释如下:
# 2 < True 等同于 False
# not False 等同于 True
# 0 and 1 返回 0(因为 0 为 False)
# 0 or True 返回 True
布尔运算顺序是先比较运算再逻辑运算,逻辑运算中如果没有括号,优先级默认是not>and>or
```
2.4布尔值
下列被视为False,其他所有值都被视为
True
。
- 数值 0
- 空字符串
""
- 空列表
[]
- 空元组
()
- 空字典
{}
- 空集合
set()
- 特殊值
None
bool(0) # False
bool(1) # True
bool("") # False
bool("Hello") # True
bool([]) # False
bool([1, 2]) # True
print(int(True)) # 输出 1
print(bool('FALSE')) # 输出 True,因为 'FALSE' 是非空字符串
print(bool(False)) # 输出 False
print(bool([ ])) # 输出 False,因为 [] 是空列表
print(bool(None)) # 输出 False
```
逻辑运算符返回值
print(3 and 0 and "hello") # 输出 0,and 运算符返回第一个 False 的值
print(3 and 0 and 5) # 输出 0,and 运算符返回第一个 False 的值
print(((2 >= 2) or (2 < 2)) and 2) # 输出 2
# (2 >= 2) 为 True,(2 < 2) 为 False
# True or False 为 True
# True and 2 返回 2
2.6布尔值与比较运算
1 == 1 # True
1 == 2 # False1 != 1 # False
1 != 2 # True2 > 1 # True
1 > 2 # False1 < 2 # True
2 < 1 # False
#>=与<=类似的
2.7布尔值与条件/循环语句
布尔值在控制程序流程的条件语句中非常重要,例如 if
语句
if True:print("This is true.")
else:print("This is false.")
布尔值也可以控制循环语句的执行,例如 while
循环。在下面的程序中,只要条件 count < 5
为真,循环就会继续执行。
count = 0
while count < 5:print(count)count += 1
3常见错误类型 & 结果类型
3 1进制转换错误
try:print(bin(12.5)) # 会报错 TypeError,因为 bin() 只接受整数
except TypeError as e:print(e)try:print(int("92", 8)) # 会报错 ValueError,因为 '92' 不是有效的八进制数字
except ValueError as e:print(e)
```
3.2类型错误
x = 'car'
y = 2
try:print(x + y) # 会报错 TypeError,因为不能将字符串与整数连接
except TypeError as e:print(e)
```
3.3表达式结果类型
print(type(1 + 2 * 3.14 > 0)) # 输出 <class 'bool'>,表达式结果为布尔值
```
4 math 模块
import math
print(math.sqrt(4) * math.sqrt(9)) # 输出 6.0
```
5. 字符串拼接
5.1直接拼接
print("hello" 'world') # 输出 helloworld,字符串直接拼接
print("hello" ,'world') # 输出 hello world, print()打印函数里面的逗号,相当于一个空格
5.2使用加号'+'
str1 = "hello"
str2 = "world"
result = str1 + " " + str2
print(result) # 输出 hello world
5.3使用join()方法
str_list = ["hello", "world"]
result = " ".join(str_list)
print(result) # 输出 hello world
5.4使用format()方法
str1 = "hello"
str2 = "world"
result = "{} {}".format(str1, str2)
print(result) # 输出 hello world
5.5使用 f-string(格式化字符串字面量)
str1 = "hello"
str2 = "world"
result = f"{str1} {str2}"
print(result) # 输出 hello world
5.6 如果需要重复一个字符串,可以使用 *
运算符
str1 = "hello"
result = str1 * 3
print(result) # 输出 hellohellohello
```
6. 复数
z = 1 + 2j
print(z.real) # 输出 1.0
print(z.imag) # 输出 2.0
print(z.conjugate()) # 输出 (1-2j),返回共轭复数
实部real 虚部imag 共轭复数conjugate
7. 字符串结束标志
在 Python 中,字符串不以 \0 结束,这是在 C 或 C++ 中的做法
```
8. 运算注意事项
print(10 / 2) # 输出 5.0,浮点运算的结果为浮点数
# 整数运算和浮点运算的结果类型取决于操作数的类型
整数运算 (+, -, *, /, %): 如果两个操作数都是整数(int),那么大多数运算(除了 /)都会返回整数;
浮点(数)运算 (+, -, *, /, %): 如果至少有一个操作数是浮点数(float),那么运算结果将是 float 类型。
第三章
一、 判断表达式的输出:
print("34" in "1234"==True)输出什么
-表达式"34" in "1234"==True返回值是 False,因为`"1234" == True`是 `False`。
print("输出结果是{:8s}".format("this"))输出什么
- 正确输出是 `输出结果是this `(右侧四个空格)。这里格式化字符串 `{8s}` 表示字符串至少有8个字符,(文本默认)左对齐。
print("输出结果是{:8d}".format(1234))`输出什么
- 正确输出是 `输出结果是 1234`(左侧四个空格)。这里格式化字符串 `{8d}` 表示数字至少有8位,(数据默认)右对齐。
print("输出结果是{:08.2f}".format(14.345))`输出什么
- 正确输出是 `00014.35`。格式化字符串 `{08.2f}` 表示浮点数总长度为8,保留两位小数,左边补零。
以下哪句打印出smith\exam1\test.txt?
print("smith\\exam1\\test.txt") √
而print("smith\exam1\test.txt")会输出smith\exam1 est.txt
print("smith\"exam1\"test.txt")会smith"exam1"test.txt
print("smith"\exam1"\test.txt")会SyntaxError: unexpected character after line continuation character
list("abcd")的结果:
['a', 'b', 'c', 'd']
`len('3//11//2018'.split('/'))`的结果:
5
分析:
括号里面相当于
x='3//11//2018'
x=x.split('/')现在x是['3', '', '11', '', '2018']所以是5
print("{1}+{0}={2}".format(2, 3, 2+3))`的输出:
3+2=5
print("{first}-{second}={0}".format(34-23, first=34, second=23))`的输出:
34-23=11
print("{:>08s}".format(bin(31)[2:]))`的输出:
00011111
二、 列表操作
- 字符串和列表都是序列类型。
- 字符串对象和元组对象是不可变对象,列表对象是可变对象。
- 列表不能使用 `find()` 函数搜索数据。(要不然为什么还会有二分法等查找方法呢)
- 列表可以使用 `append()` 方法添加元素。
例题
判断表达式:
1. "12 "*3 == " ".join(["12", "12", "12"])
返回值是 `False`。前者是121212,后者是12 12 12。
2. `[1,2,[3]]+[4,5]`的结果:
[1, 2, [3], 4, 5]
3. `[4,5]*3`的结果:
[4, 5, 4, 5, 4, 5]
```
4. `list1 = [1, 2, 3, 4, 5, 4, 3, 2, 1]` 中 `print(list1[:-1])` 的输出:
[1, 2, 3, 4, 5, 4, 3, 2]
```解:(左闭右开所以是从索引为0到-2)
5. `random.randint(0, n)` 中 n 的值:
- 如果要得到 `[0, 100]` 范围内的随机数,`n` 应该是 `100`。
解:randint()函数包括两个边界值的
6. `print("programming".find("r", 2))`的输出:
4
解: str.find()第一个参数是要搜索的子串,第二个参数是开始搜索的位置。这里从索引为2的o处开始找r输出4
7. `print("programming".find("x"))`的输出:
-1
解:str.find() 方法如果找到了子串,就返回子串在字符串中的索引位置;如果没有找到,则返回 -1
这里没找到,故返回-1
8. `print("a123".isdigit())`的输出:
False
解:str.isdigit() 是一个字符串方法,用于判断字符串中的所有字符是否都是数字
如果字符串中包含任何非数字字符,该方法将返回 False
9. `print("aABC".isalpha())`输出:
True
解: str.isalpha() 是一个字符串方法,用于判断字符串中的所有字符是否都是字母
如果字符串中包含任何非字母字符,该方法将返回 False
三、随机数操作
- `shuffle()` 不是 `random` 模块中的函数。
四、列表切片
切片应用:
-
提取子列表:
sub_list = my_list[2:6] # 输出: [2, 3, 4, 5]
-
反转列表:
reversed_list = my_list[::-1] # 输出: [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
-
复制列表:
copied_list = my_list[:] # 输出: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
例子:列表 `lst=[12, -5, -22, -10, -26, 35, 0, 49, 3, -21]` 的切片操作:
lst[0:100] # 输出:[12, -5, -22, -10, -26, 35, 0, 49, 3, -21]lst[100:] # 输出:[]lst[100] # 运行错误:IndexError: list index out of range
```
五、写法规范
5.1 `for i in a.sort()` 是错误的语句,应该改为:
a.sort()
for i in a:
``两行代码
5.2 字符串 `lower` 方法的调用规范:
c = "A"print(c.lower())
错误调用 例如print(c.lower)
lower是一个字符串对象的方法,调用的时候要在方法名后面加上一对圆括号 ()
六、列表拼接字符串的判断:
lst = ["1", "2", "3", "4", "5"]s1 = ""for c in lst:s1 = s1 + c + " "s2 = " ".join(lst)if s1 == s2:print("yes")else:print("no")
```
输出:`no`。因为 `s1` 是 `1 2 3 4 5 `(注意5后面有一个空格) 而 `s2` 是 `1 2 3 4 5`。4.
```
七、 列表操作之pop()函数:
list(range(2, 12, 2))[:-2].pop() # 输出:6
range(2,12,2):2 4 6 8 10
list:[2, 4, 6, 8, 10]
[:-2]:[2, 4, 6]
pop():是一个列表方法,用于移除列表中的最后一个元素,并返回该元素
所以输出6
```
八、 字符串处理
知识点
- `strip()`、`rstrip()` 和 `lstrip()` 方法用于移除字符串两端的特定字符。
例题(□表示空格)
1. `print("□□□xyz□□".strip(), "□□□xyz□□".rstrip(), "□□□xyz□□".lstrip())`的输出:
xyz □□□xyz xyz□□
```
九、内存地址和引用
知识点
- 浅拷贝和深拷贝的区别。
例题
1. 内存地址的比较:
a = [1, 2, 3, 4]b = aprint(id(a) == id(b)) # Truec = a.copy()print(id(a) == id(c)) # Falsed = a[:]print(id(a) == id(d)) # False
#后面为输出的结果,解释如下:
b=a:将a的引用赋值给b,此时b和a引用同一个列表对象,所以输出是True
c=a.copy():创建了a的一个浅拷贝,赋值给c,由于c是a的一个副本,它们是两个不同的对象,所以输出是False
d=a[:]:使用切片操作a[:]创建了a的一个浅拷贝,赋值给d。这种切片操作本质上和a.copy()相同,都会创建一个新的列表对象。由于d是a的一个副本,它们是两个不同的对象,所以输出是False。
```
什么时候id内存地址相同
a = "hello" a = 100 a=[1,2,3]
b = "hello" b= 100 b=a
引用相同对象(如上,都是'hello'或者100) 或者两个变量被赋予同一个对象的引用的时候,内存地址相同
```
十、运算顺序:
```python
t = 1t, a = 2, t + 1print(a) # 输出:2
a不是3,因为先运算等号右边,此时t值为1
```
十一、打印表格内容
知识点
- 使用不同方式打印表格内容。
例题
1. 三种不同方式打印表格内容:
students = [(3180102988, "褚好"),(3170102465, "王凯亮"),(3160104456, "李永"),(3171104169, "陈鑫"),(318400429, "徐杭诚")]for row in students: # 按行存取print(row[0], row[1])print()for id, name in students: # 按行拆包存取print(id, name)print()for index in range(len(students)): # 按索引存取print(students[index][0], students[index][1])
```
第四章 循环与列表(题目解析)
--1--
在循环中continue语句的作用是(结束本次循环)退出循环的当前迭代 √
带有else子句的循环如果因为执行了break语句而退出的话,会执行else子句的代码。×
分析:因为break是跳出整个循环,所以如果循环体内有else子句,且循环是通过break退出的,那么else子句中的代码也不会被执行。
当然,循环结构可以没有else子句
e.g.
for i in range(3):print(i)
下面程序的输出是3。×
lst=[34,6,7,0,0,0,9]n=0for i in lst:if i==0:lst.remove(i)n+=1print(n)
分析:第一次移除原索引为3的‘0’ 然后原索引为456分别变为345
刚刚查过3这个索引 接下来查4即查原索引为5的‘0’并移除
后面查不到0了所以总共移除了两个0
故输出应该为2,而不是3。
(思考:倘若变成列表里面0不是连着的分布的,例如:
下面输出是3
lst=[0,34,6,0,7,0,9]n=0for i in lst:if i==0:lst.remove(i)n+=1print(n)
那么输出3就是对的!)
关于可变/不变
下面程序输出值是1。×
data=[[1]*3]*3##①data[0][1]=45#②print(data[2][1])#③
①处 *3是 重复引用同一个列表三次
data = [[1, 1, 1], # 这三个内层列表实际上是同一个对象[1, 1, 1],[1, 1, 1]]
②由于这三个内层列表是相同的对象,因此修改会反映在所有引用中
现在data即
data = [[1, 45, 1],[1, 45, 1],[1, 45, 1]]
所以③输出45
思考:如果外面不是用*3
data = [[1] * 3 for i in range(3)]data[0][1] = 45print(data) # 输出 [[1, 45, 1], [1, 1, 1], [1, 1, 1]]print(data[2][1]) # 输出 1
下面程序中 ,i的循环终值是__________。
for i in range(10):print(i)
是9
(但是如果是像while i<5:这种,终值就是5 )
下面程序中语句print(i*j)共执行了___________________次。
for i in range(5):for j in range(2,5):print(i*j)
每次循环的具体输出:
1. 当 `i = 0` 时,内层循环 `j` 取值为 `[2, 3, 4]`:
- `0 * 2 = 0`
- `0 * 3 = 0`
- `0 * 4 = 0`
2. 当 `i = 1` 时,内层循环 `j` 取值为 `[2, 3, 4]`:
- `1 * 2 = 2`
- `1 * 3 = 3`
- `1 * 4 = 4`
3. 当 `i = 2` 时,内层循环 `j` 取值为 `[2, 3, 4]`:
- `2 * 2 = 4`
- `2 * 3 = 6`
- `2 * 4 = 8`
4. 当 `i = 3` 时,内层循环 `j` 取值为 `[2, 3, 4]`:
- `3 * 2 = 6`
- `3 * 3 = 9`
- `3 * 4 = 12`
5. 当 `i = 4` 时,内层循环 `j` 取值为 `[2, 3, 4]`:
- `4 * 2 = 8`
- `4 * 3 = 12`
- `4 * 4 = 16`
外层是5次 内层是3次 总共15次
执行下面程序产生的结果是___________________。
x=2;y=2.0 #分号可把两个语句写在一行if(x==y):print("相等")else:print("不相等")
相等
注:Python 在比较两个不同类型的数值时会进行类型转换,这种转换称为“隐式类型转换”或“类型强制”。在这种情况下,Python 会将整数 x 转换为浮点数(如果需要的话),或者将浮点数 y 转换为整数(如果需要的话),以便进行比较。由于 2 和 2.0 的数值相同
注意 如果for i in range(10,0)这种步长非负并且参数1比参数2大的,range就不产生任何值
下面程序输出什么?
for i in range(1,5):j=0while j<i:print(j,end=" ")j+=1print()
会输出以下↓
0
0 1
0 1 2
0 1 2 3
下面程序运行后输出是
a = [1, 2, 3, 4, [5, 6], [7, 8, 9]] #一个列表s = 0for row in a: #遍历a中的元素if type(row)==list: #检查元素是否为列表for elem in row: #处理嵌套列表s += elemelse: #处理非列表元素s+=rowprint(s)
所以即算列表和 为45
下面程序运行后输出是_________。
l3=[i+j for i in range(1,6) for j in range(1,6)]print(sum(l3))
嵌套循环 相当于
for i in range(1, 6):for j in range(1, 6):l3.append(i + j)
先固定一个i比如说i为1,j从1到5,生成i+j即2,3,4,5,6
接下来i是2,j从1到5……以此类推
总和就是2加到6 + 3加到7 + 4到8 + 5到9 + 6到10
即20 + 25 + 30 +35 + 40 即150
下面程序运行后输出是_________。
l3=[[(i,j) for i in range(1,6)] for j in range(1,6)]print(l3[2][1][0])
分析:这个列表生成式创建了一个5x5的二维列表,其中每个元素都是一个元组 (i, j)。外层列表生成式遍历 j 从 1 到 5,内层列表生成式遍历 i 从 1 到 5。
l3 = [
[(1, 1), (2, 1), (3, 1), (4, 1), (5, 1)], # 当 j = 1
[(1, 2), (2, 2), (3, 2), (4, 2), (5, 2)], # 当 j = 2
[(1, 3), (2, 3), (3, 3), (4, 3), (5, 3)], # 当 j = 3
[(1, 4), (2, 4), (3, 4), (4, 4), (5, 4)], # 当 j = 4
[(1, 5), (2, 5), (3, 5), (4, 5), (5, 5)] # 当 j = 5
]
所以是 2
下面程序运行后,最后一行输出是_________。
n = 3m = 4a = [0] * n #a = [0, 0, 0]for i in range(n):a[i] = [0] * m #在每次迭代中将 a[i] 赋值为一个长度为 4 的列表 [0, 0, 0, 0]print(a[0][2])
分析:
前三行
n 被设置为 3,表示列表 a 将有3个子列表。
m 被设置为 4,表示每个子列表将有4个元素。
a = [0] * n 创建一个包含 3 个元素的列表,每个元素初始为 0。
迭代分析:
第一轮i=0 a[0] 赋值为 [0, 0, 0, 0] 所以a = [[0, 0, 0, 0], 0, 0] 输出0
第二轮i=1 a[1] 赋值为 [0, 0, 0, 0] 所以a = [[0, 0, 0, 0], [0, 0, 0, 0], 0] 输出0
第三轮i=2 a[2] 赋值为 [0, 0, 0, 0] 所以a = [[0, 0, 0, 0], [0, 0, 0, 0], [0, 0, 0, 0]] 输出0
最终输出
0
0
0
所以答案为 0
关于列表的引用
下面程序的输出是
row=[0]*3 #创建列表[0, 0, 0]data=[row,row,row] #创建了一个二维列表 data,其每一行都引用同一个 row 列表data[2][2]=7 # data 的第三行第三列的值设置为 7。由于所有行都引用同一个 row 列表#因此这个操作会影响到所有引用 row 列表的地方print(data[0][2])
初始
row = [0, 0, 0]data = [row, # [0, 0, 0]row, # [0, 0, 0]row # [0, 0, 0]]
data[2][2] = 7 相当于 row[2] = 7
现在
data = [
[0, 0, 7],
[0, 0, 7],
[0, 0, 7]
]
所以结果是 7
下面程序的输出是
data=[[0]*3] *3 #使用的是 [[0] * 3] * 3,所以 data 中的3个子列表实际上是同一个列表的引用data[2][2]=7 #由于所有行都引用同一个列表,这个操作会影响所有引用该列表的地方print(data[0][2])
分析:所以答案是 7
下面程序的输出是
data=[]for i in range(3):data.append([0]data[2][2]=7print(data[0][2])
分析:使用循环 for i in range(3) 遍历3次,每次迭代中,向 data 添加一个包含3个元素 [0, 0, 0] 的新列表。这样,data 中的每一行都是独立的列表
data[2][2] = 7 这个修改只会影响 data[2]
初始
data = [[0, 0, 0], # 第一次迭代添加的列表[0, 0, 0], # 第二次迭代添加的列表[0, 0, 0] # 第三次迭代添加的列表]
修改后
data = [
[0, 0, 0],
[0, 0, 0],
[0, 0, 7]
]
所以结果是0
下面程序的输出是
mat=[[i*3+j+1 for j in range(3)] for i in range(5)]mattrans=[[row[col] for row in mat] for col in range(3)]print(mattrans[1][3])
分析:①mat = [[i*3 + j + 1 for j in range(3)] for i in range(5)]这一行
外层循环遍历 i 从 0 到 4,共 5 次(生成 5 行)。
内层循环遍历 j 从 0 到 2,共 3 次(生成 3 列)。
每个元素的值为 i * 3 + j + 1。
具体生成的mat矩阵如下
mat = [[1, 2, 3], # 当 i = 0[4, 5, 6], # 当 i = 1[7, 8, 9], # 当 i = 2[10, 11, 12], # 当 i = 3[13, 14, 15] # 当 i = 4]
②mattrans = [[row[col] for row in mat] for col in range(3)]这一行
外层循环遍历 col 从 0 到 2(生成转置后的3行)。
内层循环遍历 mat 中的每一行,提取第 col 列的元素,形成转置后的列。
mattrans = [[1, 4, 7, 10, 13], # 第0列转成第0行[2, 5, 8, 11, 14], # 第1列转成第1行[3, 6, 9, 12, 15] # 第2列转成第2行]
即转置列表 输出是11
第五章 集合与字典的基本知识与应用
1.集合基本知识
Python 的集合(set)是一个无序的不重复元素序列。它使用大括号 {} 或者 set() 函数创建。由于集合是无序的,所以它不支持索引操作,也没有切片功能。
集合具有以下基本特性:
无序性:集合中的元素没有固定的顺序。
确定性:集合中的元素是不重复的,即集合中不存在重复的元素。
互异性:集合中的元素必须是不可变类型,例如整数、浮点数和字符串等。
1.1集合的元素 添加&删除
- 集合的元素可以是任意数据类型。×
- 错误:集合的元素不能是可变的数据类型,比如列表和字典。
- 集合的元素去重特性。
- `len(set([0,4,5,6,0,7,8]))` 的结果是 6。
- 因为集合会去除重复元素(即去除两个0中的一个)。
-添加与删除元素
添加元素可以用'add()'方法
初始set1={1,2,3,4}
set1.add(5)
print(set1) # 输出: {1, 2, 3, 4, 5}
接着,删除元素可以使用 remove()
方法。如果元素不存在,会引发 KeyError
。
set1.remove(3)
print(set1) # 输出: {1, 2, 4, 5}
删除元素也可以使用 discard()
方法。如果元素不存在,不会引发错误。
set1.discard(6) # 不会引发错误
1.2集合的创建
- 创建集合
- `a = {}` 创建的是一个空字典,而不是集合。
- 创建空集合应使用 `a = set()`。
例如 :使用 set()
函数创建一个空集合。👇
empty_set = set()
print(empty_set) # 输出: set()
注意:使用花括号 {}
可以创建一个非空集合。👇
set1 = {1, 2, 3, 4}
print(set1) # 输出: {1, 2, 3, 4}
1.3集合的操作
- 无序性
- 下面程序的运行结果不一定是 `1 2 3 4`:
set1={1,2,3,4}for i in set1:print(i,end=" ")
- 分析:集合是无序的,因此元素的打印顺序不是固定的。
```
- 集合运算
- `s1 < s2` 表示 `s1` 是 `s2` 的真子集。
- 不存在的集合操作:`s.append(1)`,应使用 `s.add(1)`。
2.字典基本知识
2.1字典的键
- 字典的键必须是不可变的。
- 列表是可变的,因此列表不能作为字典的键。
2.2访问字典
- 访问字典元素
- `dic[i]` 访问字典元素时,键 `i` 必须存在,否则会引发 `KeyError` 异常。
- `dic.get("张军", None)` 如果键不存在,返回 `None`,不会引发异常。
e.g.
dic = {"赵洁": 15264771766}print(dic["张军"]) # 如果键不存在会引发 KeyError
2.3字典操作(键值对反转&字典合并)
- 字典的键值对反转
dic = {"赵洁" : 15264771766, "张秀华" : 13063767486, "胡桂珍" : 15146046882}reversedic = {v:k for k,v in dic.items()}print(reversedic[13063767486]) # 输出 "张秀华"
```
- 字典合并
- `dic1.update(dic2)` 更新 `dic1` 的内容,并返回 `None`。
- `dic3 = {**dic1, **dic2}` 合并 `dic1` 和 `dic2`,键冲突时 `dic2` 中的值覆盖 `dic1` 中的值。
dic1 = {"赵洁" : 15264771766}dic2 = {"张秀华" : 13063767486}dic1.update(dic2)print(dic1 == {**dic1, **dic2}) # 输出 True
```
- 合并后重复键覆盖
dic1 = {"胡桂珍": 15146046882}dic2 = {"胡桂珍": 13292597821}dic3 = {**dic1, **dic2}print(dic3["胡桂珍"]) # 输出 13292597821
```
3.数据结构总结
-3.1 创建空数据结构
- 集合(Set):`set()`
- 字典(Dictionary):`{}`
- 列表(List):`[]`
- 元组(Tuple):`()`
- 3.2可变与不可变
- 可变:列表、字典、集合
- 不可变:元组
4 相关题目
4.0正确数据结构选择
- 哪一句会得到 `{'1','2','3'}`?
A.list("123")
B.tuple("123")
C.set("123")
D.以上都不是
set("123") # 输出 {'1', '2', '3'}
分析:list("123") 将字符串 "123" 转换为一个列表,其中每个字符作为一个元素。
结果是 ['1', '2', '3']。
而tuple("123") 将字符串 "123" 转换为一个元组,其中每个字符作为一个元素。
结果是 ('1', '2', '3')
- 4.1输出字典中的键
dic = {"赵洁": 15264771766}print("张秀华" in dic) # 输出 False
```
- 4.2删除字典中的键值对
dic = {"赵洁": 15264771766, "张秀华": 13063767486}del dic["张秀华"]print(dic) # 输出 {'赵洁': 15264771766}
```
- 4.3输出字典中某个键的平方值
squares = {x: x*x for x in range(20)}print(squares[12]) # 输出 144
```
- 4.4计算字符串中单词的长度
text = "four score and 7 years"lenwords = {s: len(s) for s in text.split()}print(lenwords["score"]) # 输出 5
```
- 4.5合并两个字典
dic1 = {"姓名": "xiaoming", "年龄": 27}dic2 = {"性别": "male", "年龄": 30}dic3 = {k: v for d in [dic1, dic2] for k, v in d.items()}print(dic3["年龄"]) # 输出 30
```
- 4.6访问二维列表中的元素
cells = {"values": [[100, 90, 80, 90], [95, 85, 75, 95]]}print(cells["values"][1][2]) # 输出 75
```
- 4.7列表推导式
myth = [{'label': color, 'value': color} for color in ['blue', 'red', 'yellow']]print(myth[1]["label"]) # 输出 'red'
```
第六章 函数(题目分析)
-函数也是对象,下面程序可以正常运行吗?
def func(): #这里定义了一个名为 func 的函数,它 print("11",end=" ") #在被调用时打印字符串 "11",并且在末尾不换行。print(id(func),type(func),func) #获取'func'的内存地址,类型,表现形式
(通常是内存地址和函数名)
分析:
会正常运行e.g.输出2352392832160 <class 'function'> <function func at 0x00000223B58A04A0>
函数本质上是对象,可以存储于数据结构(如列表字典)当中
函数对象,类型为 <class 'function'>
-形参和return语句都是可有可无的√
分析:在Python中定义函数时,不可省略的↓
def 关键字:定义函数时必须使用 def 关键字。
函数名称:紧跟在 def 关键字之后的是函数的名称,这是必须的,用于标识函数。
参数列表:即使函数不需要参数,也必须有一对空括号 (),用于定义参数列表。
函数体:至少需要一个冒号 : 和一个缩进的代码块,即函数体,即使它是空的。
例如,一个最简单的函数定义如下:
def foo():…
这里…是ellipsis object(省略号对象)
形参:
在编程语言中,形参(Formal Parameter)是函数定义中用于接收传递给函数的值的变量。当函数被调用时,形参会被实际的参数(Argument)所替代,这些实际的参数是调用函数时提供的值。
例如,考虑以下Python函数定义:
def greet(name):print("Hello, " + name + "!")
在这个函数中,name 就是一个形参。当你调用这个函数并传递一个实际的参数时,比如 greet("Alice"),name 形参就会被 "Alice" 这个实际参数所替代,并且函数会输出 "Hello, Alice!"。
-在一个函数中如局部变量和全局变量同名,则局部变量屏蔽全局变量
√
例如
x = 10 # 全局变量def my_function():x = 20 # 局部变量,屏蔽全局变量xprint("Inside the function, x =", x)my_function() # 调用函数
print("Outside the function, x =", x)
#会输出↓
#Inside the function, x = 20
#Outside the function, x = 10
-area是tri模块中的一个函数,执行from tri import area 后,调用area函数应该使用____ 。
area()
分析:
当你使用 from tri import area 导入语句时,你直接将 area 函数从 tri 模块导入到当前的命名空间中。这意味着你可以直接使用 area() 来调用该函数,而不需要模块名称作为前缀。
如果我们用的是 import tri 那么调用area函数要用tri.area()例如
import tri# 调用tri模块中的area函数triangle_area = tri.area(base=10, height=5)
-函数可以改变哪种数据类型的实参?
int:整数 是不可变数据类型
string:字符串 是不可变数据类型
float:浮点数 是不可变数据类型
-list :列表是可变数据类型,函数内部可以改变原始的列表实参
-函数定义如下,程序输出是什么
def f1(a,b,c):print(a+b)nums=(1,2,3)f1(nums)
分析:
f1 函数期望接收三个参数 a, b, c,但 f1(nums) 只传递了一个参数 nums;这里的nums相当于参数a。这会导致函数调用时参数数量不匹配(b和c没有)的错误
修正
def f1(a, b, c):print(a + b)nums = (1, 2, 3)f1(*nums)
会输出3
①函数参数数量匹配:函数调用时传递的参数数量必须与函数定义时的参数数量匹配。
②拆包操作:使用 * 操作符可以将一个可迭代对象解包为单独的元素并传递给函数,确保参数数量匹配。
-下面程序运行结果是
def fun(x1,x2,x3,**x4): print(x1,x2,x3,x4)fun(x1=1,x2=22,x3=333,x4=4444)
分析:在函数定义中,**x4 会将所有多余的关键字参数以字典的形式捕获到 x4 中。如果你传递一个与 x4 同名的参数,那么它会被视为一个普通参数,而不是被捕获到 **x4 中。例如:
def fun(x1, x2, x3, **kwargs):print(x1, x2, x3, kwargs)fun(x1=1, x2=22, x3=333, extra=4444)
输出结果是
1 22 333 {'extra': 4444}
所以本题将输出
1 22 333 {'x4': 4444}
下列程序将输出什么
def scope():n=4m=5print(m,n,end=' ')n=5t=8scope()print(n,t)
分析:
局部作用域:在函数内部定义的变量只在函数内部有效,不会影响全局作用域中的变量。
全局作用域:在函数外部定义的变量在整个程序中有效,除非在函数内部用 global 关键字声明,否则函数内部对同名变量的修改不会影响全局变量。
n = 5
t = 8
在全局作用域中,定义了两个变量 n 和 t,分别赋值为 5 和 8。
scope()
调用 scope 函数,执行函数内部的代码。
在 scope 函数的本地作用域中,定义了局部变量 n 和 m,分别赋值为 4 和 5。
print(m, n, end=' ') 输出局部变量 m 和 n 的值,即 5 和 4。输出 5 4 .
print(n, t)
打印全局作用域中的变量 n 和 t,它们的值依然是 5 和 8。输出 5 8。
所以最后输出5 4 5 8
关于输出5 4与5 8要不要换行:
print(m, n, end=' ') 输出 5 4,并在末尾添加一个空格,光标停在这一行的空格之后;紧接着上一步的输出,在同一行,print(n, t) 输出 5 8。
如果删去 print(m,n,end=' ')中的end=' '则会换行
输出
5 4
5 8
-下面程序运行结果是什么
def nprintf(message,n):for i in range(n):print(message,end=" ")nprintf("a",3,)nprintf(n=5,message="good")
分析:
函数实现功能是输出n个message
所以
nprintf("a",3,)
会输出
'a a a '(注意每个a后面都有一个空格)
nprintf(n=5,message="good")
会输出
'good good good good good '(每一个good后面也有一个空格)
所以原代码输出
'a a a good good good good good '
-下面程序输出是什么
lst=[(1,"one"),(2,"two"),(3,"three"),(4,"four")]lst.sort(key=lambda x:x[1])print(lst[3][1][2])
分析:
lst = [(1, "one"), (2, "two"), (3, "three"), (4, "four")] #定义了一个列表lst.sort(key=lambda x: x[1]) #排序 sort 方法使用 key=lambda x: x[1] 对 lst 进行排序,这表示按照每个元组的第二个元素(即字符串部分)进行排序。
排序后 [(4, "four"), (1, "one"), (3, "three"), (2, "two")]
print(lst[3][1][2]) [3]访问列表第四个元素即(2, "two")
[1]访问该元组的第二个元素即two字符串
[2]访问字符串two的第三个元素 即o
所以输出o
-下列程序第四行输出什么
def perm(choice,selected=[]):if len(choice)==1:print("".join(selected+choice))else:for i in range(len(choice)):t=choice[i]choice.remove(t)selected.append(t)perm(choice,selected)choice.insert(i,t)selected.pop()first=["1","2","3"]perm(first,selected=[])
分析:
重点在于递归函数‘perm’的工作机制
基准:
当 choice 列表的长度为 1 时,将 selected 列表和 choice 列表连接起来,并打印结果。
递归:
遍历 choice 列表中的每个元素,将其移除并加入到 selected 列表中。
递归调用 perm 函数来处理剩余的 choice 列表。
递归调用结束后,将移除的元素重新插入到 choice 列表中的原位置,并从 selected 列表中移除
def perm(choice, selected=[]): # 定义一个函数 perm,接受两个参数 choice 和 selected,默认 selected 是一个空列表if len(choice) == 1: # 如果 choice 的长度为 1print("".join(selected + choice)) # 打印 selected 和 choice 的组合(将列表转换为字符串)else: # 否则for i in range(len(choice)): # 遍历 choice 列表的每个索引t = choice[i] # 取出 choice 列表中索引为 i 的元素choice.remove(t) # 从 choice 列表中移除该元素selected.append(t) # 将该元素添加到 selected 列表中perm(choice, selected) # 递归调用 perm 函数,传入修改后的 choice 和 selected 列表choice.insert(i, t) # 在 choice 列表的索引 i 处插入元素 t(恢复原样)selected.pop() # 从 selected 列表中移除最后一个元素(恢复原样)# 例如调用 perm(["a", "b", "c"]) 将打印:# abc# acb# bac# bca# cab# cba
具体分析如下:
初始调用
first = ["1", "2", "3"]
perm(first, selected=[])
第一层递归:
选择 "1":
choice = ["2", "3"]
selected = ["1"]
perm(["2", "3"], ["1"])
选择 "2":
choice = ["1", "3"]
selected = ["2"]
perm(["1", "3"], ["2"])
选择 "3":
choice = ["1", "2"]
selected = ["3"]
perm(["1", "2"], ["3"])
第二层递归:
选择 "1" 后:
choice = ["3"]
selected = ["1", "2"]
perm(["3"], ["1", "2"])
输出 123
choice = ["2"]
selected = ["1", "3"]
perm(["2"], ["1", "3"])
输出 132
选择 "2" 后:
choice = ["3"]
selected = ["2", "1"]
perm(["3"], ["2", "1"])
输出 213
choice = ["1"]
selected = ["2", "3"]
perm(["1"], ["2", "3"])
输出 231
选择 "3" 后:
choice = ["2"]
selected = ["3", "1"]
perm(["2"], ["3", "1"])
输出 312
choice = ["1"]
selected = ["3", "2"]
perm(["1"], ["3", "2"])
输出 321
总结输出
最终,这段代码将会输出所有 ["1", "2", "3"] 的排列:
123
132
213
231
312
321
所以第四行输出231
-在Python中,函数是对象,可以像其他数据对象一样使用。下面程序的输出是
def func1():print("11",end=" ")def func2():print("22",end=" ")def func3():print("33",end=" ")funclist=[func1,func2,func3]for func in funclist:func()
分析:
def func1():print("11", end=" ") # 定义函数 func1,打印 "11",输出后不换行,而是输出一个空格def func2():print("22", end=" ") # 定义函数 func2,打印 "22",输出后不换行,而是输出一个空格def func3():print("33", end=" ") # 定义函数 func3,打印 "33",输出后不换行,而是输出一个空格funclist = [func1, func2, func3] # 创建一个函数列表 funclist,包含 func1, func2 和 func3for func in funclist: # 遍历 funclist 列表中的每个函数func() # 调用当前函数
使用 `for` 循环遍历 `funclist` 列表中的每个函数,并调用它们。
- 第一次循环时,`func` 是 `func1`,所以调用 `func1()`,输出 "11 "。
- 第二次循环时,`func` 是 `func2`,所以调用 `func2()`,输出 "22 "。
- 第三次循环时,`func` 是 `func3`,所以调用 `func3()`,输出 "33 "。
最终,代码的输出结果是:
```
11 22 33
```
每个函数的输出在一行上连续打印出来,因为我们使用了 `end=" "` 参数来防止打印后的换行。这展示了如何将函数视作一等公民(first-class citizens),即它们可以被赋值给变量、存储在数据结构中,并在需要时调用。
-下面程序的输出是
f = lambda p:p+5t = lambda p:p*3x=7x=f(x)x=t(x)x=f(x)print(x)
分析:
f = lambda p: p + 5 # 定义一个 lambda 函数 f,它接受一个参数 p,并返回 p + 5t = lambda p: p * 3 # 定义另一个 lambda 函数 t,它接受一个参数 p,并返回 p * 3x = 7 # 定义一个变量 x,初始值为 7x = f(x) # 调用函数 f,将 x 的值(7)加 5,结果是 12,x 变为 12x = t(x) # 调用函数 t,将 x 的值(12)乘以 3,结果是 36,x 变为 36x = f(x) # 再次调用函数 f,将 x 的值(36)加 5,结果是 41,x 变为 41print(x) # 打印 x 的最终值,输出 41
总结每一步的变化:
- 初始值:`x = 7`
- 第一次调用 `f(x)` 后:`x = 12`
- 第二次调用 `t(x)` 后:`x = 36`
- 第三次调用 `f(x)` 后:`x = 41`
最终输出结果是:
```
41
```
-下面程序的输出是
def factorial(n):match n:case 0 | 1:return 1case _:return n * factorial(n - 1)print(factorial(5))
分析:
def factorial(n):match n: # 使用 match 语句对 n 进行模式匹配case 0 | 1: # 如果 n 是 0 或 1return 1 # 返回 1,这是阶乘的基例case _: # 对于所有其他情况return n * factorial(n - 1) # 返回 n 乘以 factorial(n - 1) 的结果,这是阶乘的递归定义print(factorial(5)) # 调用 factorial(5),计算 5 的阶乘并打印结果
这段代码使用 引入的 `match` 语句来实现一个递归的阶乘函数。
逐步解析最后一行这个调用的执行过程:
- `factorial(5)` 触发 `case _`,返回 `5 * factorial(4)`
- `factorial(4)` 触发 `case _`,返回 `4 * factorial(3)`
- `factorial(3)` 触发 `case _`,返回 `3 * factorial(2)`
- `factorial(2)` 触发 `case _`,返回 `2 * factorial(1)`
- `factorial(1)` 触发 `case 0 | 1`,返回 `1`
通过递归调用,我们得到:
- `factorial(2)` = `2 * 1` = `2`
- `factorial(3)` = `3 * 2` = `6`
- `factorial(4)` = `4 * 6` = `24`
- `factorial(5)` = `5 * 24` = `120`
最终,代码的输出结果是:
```
120
```
-下列程序运行结果是
l=[1]def scope1():l.append(6) print(*l)scope1()
分析:
这段代码定义了一个列表 `l` 和一个函数 `scope1()`,然后调用了这个函数。逐行解析这段代码的作用及其输出结果,如下。
l = [1] # 定义一个列表 l,初始值为 [1]def scope1():l.append(6) # 向列表 l 中添加一个元素 6print(*l) # 使用 * 运算符解包列表 l 的元素,并将其传递给 print 函数,打印列表中的所有元素,中间用空格分隔scope1() # 调用 scope1 函数,执行上述操作
最终输出结果是:
```
16
```
在这段代码中,由于列表 `l` 是在全局作用域中定义的,函数 `scope1` 可以直接访问和修改全局变量 `l`。(即 Python 中列表作为可变对象的特性)
-下面程序运行结果是
a=10def func():global aa=20print(a,end=' ')func()print(a)
分析:
这段代码演示了如何在 Python 中使用 `global` 关键字来修改全局变量。让我们逐行解析代码的作用及其输出结果。
a = 10 # 定义一个全局变量 a,初始值为 10def func():global a # 声明 a 是一个全局变量a = 20 # 将全局变量 a 的值修改为 20print(a, end=' ') # 打印 a 的值(20),输出后不换行,而是输出一个空格func() # 调用 func 函数,打印 20,光标停在同一行print(a) # 打印全局变量 a 的值,此时 a 的值为 20
代码的执行过程如下:
1. 定义全局变量 `a` 并赋值为 `10`。
2. 定义函数 `func`,在函数内部使用 `global` 关键字声明并修改全局变量 `a` 的值为 `20`,然后打印 `20`。
3. 调用函数 `func`,打印出 `20`。
4. 在函数调用之后,再次打印全局变量 `a` 的值,此时 `a` 的值为 `20`。
最终输出结果是:
```
20 20
```
这段代码展示了如何在 Python 中使用 `global` 关键字来修改和访问全局变量。
-下面程序的运行结果是
b, c=2, 4def g_func(d):global aa=d*cg_func(b)print(a)
分析:
b, c = 2, 4 # 定义两个全局变量 b 和 c,分别赋值为 2 和 4def g_func(d):global a # 声明 a 是一个全局变量a = d * c # 计算 d 和全局变量 c 的乘积,并将结果赋值给全局变量 ag_func(b) # 调用 g_func 函数,传入 b 的值(即 2)。因此,函数内执行 a = 2 * 4,a 被赋值为 8print(a) # 打印全局变量 a 的值,输出 8
-下面程序的运行结果是
import mathdef factors(x):y=int(math.sqrt(x))for i in range(2,y+1):if (x%i ==0):factors(x//i)breakelse:print(x,end=' ')returnfactors(38)
分析:
这是一个找质因数(能整除给定正整数的质数)的程序
import math # 导入数学库,以便后面可以使用其中的数学函数def factors(x): # 定义一个名为factors的函数,它接受一个参数x,表示要找质因数的数y = int(math.sqrt(x)) # 计算x的平方根,并转换为整数,因为质因数不会超过其平方根for i in range(2, y + 1): # 从2开始遍历到y+1(包括y),这个范围内的数都有可能是x的质因数if x % i == 0: # 如果x可以被i整除,说明i是x的一个质因数factors(x // i) # 递归调用factors函数,找出x // i的质因数break # 找到一个质因数就可以停止了,使用break退出循环else: # 如果x不能被当前的i整除,说明i不是x的质因数print(x, end=' ') # 直接打印出x,end=' '是为了让打印出的数横向排列,而不是换行return # 返回,结束函数# 调用函数factors,传入参数38factors(38)#输出19
-下列程序运行结果是什么
def ins_sort_rec(seq, i):if i == 0: returnins_sort_rec(seq, i - 1)j = iwhile j > 0 and seq[j - 1] > seq[j]:seq[j - 1], seq[j] = seq[j], seq[j - 1]j -= 1seq = [3,-6,79,45,8,12,6,8]ins_sort_rec(seq, len(seq)-1)print(seq[5])
分析:这是一段对列表序列排序的代码
def ins_sort_rec(seq, i): # 定义递归插入排序函数,参数为待排序序列seq和当前索引iif i == 0: return # 基本情况:如果索引i为0,返回(递归结束条件)ins_sort_rec(seq, i - 1) # 递归调用自身,将当前索引减1j = i # 初始化j为当前索引iwhile j > 0 and seq[j - 1] > seq[j]: # 循环条件:j大于0且前一个元素大于当前元素seq[j - 1], seq[j] = seq[j], seq[j - 1] # 交换前一个元素和当前元素j -= 1 # 将j减1,继续向前比较并交换seq = [3, -6, 79, 45, 8, 12, 6, 8] # 定义待排序的序列ins_sort_rec(seq, len(seq) - 1) # 调用递归插入排序函数,对序列进行排序,初始索引为最后一个元素的索引print(seq[5]) # 输出排序后序列的第6个元素#排完序seq=[-6, 3, 6, 8, 8, 12, 45, 79]所以第六个是12
-下面程序的运行结果是
def basic_lis(seq):l=[1]*len(seq)for cur ,val in enumerate(seq): #enumerate返回元素的"索引和值"for pre in range(cur):if seq[pre]<val:l[cur]=max(l[cur],1+l[pre])return max(l)L=[49, 64, 17, 100, 86, 66, 78, 68, 87, 96, 19, 99, 35]print(basic_lis(L))
分析:
def basic_lis(seq):l = [1] * len(seq) # 初始化一个长度为seq的列表l,每个元素初始值为1,表示每个元素的最长递增子序列长度至少为1for cur, val in enumerate(seq): # 枚举seq中的元素及其索引for pre in range(cur): # 对当前元素之前的每个元素进行检查if seq[pre] < val: # 如果前一个元素小于当前元素l[cur] = max(l[cur], 1 + l[pre]) # 更新l[cur]为当前最大值,表示包括当前元素在内的最长递增子序列长度return max(l) # 返回列表l中的最大值,即最长递增子序列的长度L = [49, 64, 17, 100, 86, 66, 78, 68, 87, 96, 19, 99, 35] # 定义一个待处理的序列print(basic_lis(L)) # 调用basic_lis函数并输出其结果
核心重点在下面这段代码的理解
for cur, val in enumerate(seq):for pre in range(cur):if seq[pre] < val:l[cur] = max(l[cur], 1 + l[pre])
外层循环枚举 seq 中的每个元素及其索引。内层循环遍历当前元素之前的所有元素,检查是否存在递增关系(即 seq[pre] < val)。
如果存在递增关系,则更新 l[cur] 的值为 l[cur] 和 1 + l[pre] 中的较大值。这意味着如果当前元素 val 能接在前面的递增子序列后面,则更新当前元素的最长递增子序列长度。
对于给定的序列 L = [49, 64, 17, 100, 86, 66, 78, 68, 87, 96, 19, 99, 35],它的最长递增子序列是 [49, 64, 66, 68, 87, 96, 99],其长度为7。
-下面程序是冒泡排序的实现,请填空(答案中不要有空格)
def bubble(List):for j in range(________,0,-1):for i in range(0,j):if List[i]>List[i+1]:List[i],List[i+1]=List[i+1],List[i]return Listtestlist = [49, 38, 65, 97, 76, 13, 27, 49]print( bubble(testlist))
分析:由于range是左闭右开,而索引从0开始,所以最后一个元素索引是len(List)-1
def bubble(List):for j in range(len(List) - 1, 0, -1): # 外层循环,从列表长度减1到1for i in range(0, j): # 内层循环,从列表开头到jif List[i] > List[i + 1]: # 如果当前元素大于下一个元素List[i], List[i + 1] = List[i + 1], List[i] # 交换这两个元素return Listtestlist = [49, 38, 65, 97, 76, 13, 27, 49]print(bubble(testlist)) # 输出排序后的列表
-下面程序是选择排序的实现,请填空(答案中不要有空格)
def selSort(nums):n = len(nums)for bottom in range(n-1):mi = bottomfor i in range(_________, n):if nums[i] < nums[mi]:mi = inums[bottom], nums[mi] = nums[mi], nums[bottom]return numsnumbers = [49, 38, 65, 97, 76, 13, 27, 49]print(selSort(numbers))
分析:
在选择排序算法中,需要在未排序部分寻找最小值,并将其与当前循环位置的元素交换。
因此,内层循环的起始位置应该是 bottom + 1或者bottom。
def selSort(nums):n = len(nums) # 计算列表的长度for bottom in range(n - 1): # 外层循环,遍历列表的每一个元素,除了最后一个mi = bottom # 假设当前索引bottom是最小值的索引for i in range(bottom + 1, n): # 内层循环,从bottom + 1(或者bottom)开始,遍历剩余未排序的部分if nums[i] < nums[mi]: # 如果找到一个更小的元素mi = i # 更新最小值的索引为inums[bottom], nums[mi] = nums[mi], nums[bottom] # 交换当前元素和找到的最小元素return nums # 返回排序后的列表numbers = [49, 38, 65, 97, 76, 13, 27, 49]print(selSort(numbers)) # 输出排序后的列表
第七章 文件和异常(题目分析)
一、判断题
1. 以"w"模式打开的文件无法进行读操作。
- 正确。以 "w" 模式(写入模式)打开文件时,只允许写操作,不能进行读操作。如果尝试读操作会引发错误。
2. Pandas库是用于图像处理的库。
- 错误。Pandas库主要用于数据处理和分析,不是用于图像处理的。图像处理通常使用Pillow或OpenCV等库。
3. read函数返回的是列表。
- 错误。`read`函数读取文件的全部内容,并以字符串形式返回,而不是列表。
4. readlines函数返回的是列表。
- 正确。`readlines`函数读取文件的所有行,并以列表形式返回,每行作为列表中的一个元素。
5. DataFrame是Pandas模块的一种数据类型。
- 正确。`DataFrame`是Pandas库中用于表示二维数据表的主要数据结构。
6. Json数据格式只能用于Javascript语言。
- 错误。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,不仅限于JavaScript语言,广泛应用于多种编程语言中。
7. close函数用于文件关闭。
- 正确。`close`函数用于关闭文件对象,释放与文件相关的资源。
8. Plotly模块可以画柱状图。
- 正确。Plotly模块功能强大,可以用于绘制多种图表,包括柱状图。
9. sys.stdin表示标准输入。
- 正确。`sys.stdin`是Python中表示标准输入流的对象,通常用于从控制台读取输入。
10. 第三方模块要先安装才能使用。
- 正确。第三方模块通常不包含在Python的标准库中,需要通过`pip`或其他包管理工具先安装才能使用。
11.
import plotly.graph_objects as gofig = go.Figure(data=[go.Table(header=dict(values=['A Scores', 'B Scores']),cells=dict(values=[[100, 90, 80, 90], [95, 85, 75, 95]]))]) fig.show()
上面程序的输出是下图。
- 正确。这段代码使用Plotly库绘制了一个表格,表格头是 'A Scores' 和 'B Scores',对应的值是两个列表。输出确实是一个表格。
代码分析:
导入模块:
import plotly.graph_objects as go
: 导入Plotly中的graph_objects模块并命名为go
。创建Figure对象:
fig = go.Figure(...)
: 创建一个Figure对象,表示一个可视化图表。添加数据:
data=[go.Table(...)]
: 添加一个Table(表格)对象到Figure中。header=dict(values=['A Scores', 'B Scores'])
: 定义表格的头部,包含两列,列标题分别是 'A Scores' 和 'B Scores'。cells=dict(values=[[100, 90, 80, 90], [95, 85, 75, 95]])
: 定义表格的单元格内容。第一个列表[100, 90, 80, 90]
是 'A Scores' 列的分数,第二个列表[95, 85, 75, 95]
是 'B Scores' 列的分数。显示图表:
fig.show()
: 显示创建的图表。
12. 表达式 "3/0" 会引发“ValueError”异常。
- 错误。表达式 `3/0` 会引发 `ZeroDivisionError` 异常,而不是 `ValueError`。
13. 带有else子句的异常处理结构,如果不发生异常则执行else子句中的代码。
- 正确。在异常处理结构中,`else`子句只有在没有发生异常时才会执行。
14. 在异常处理结构中,不论是否发生异常,finally子句中的代码总是会执行的。
- 正确。`finally`子句中的代码无论是否发生异常,总是会执行,常用于清理资源。
二、单选题
1.下面程序的输出是什么?
try:x=float("abc123")print("The conversion is completed")
except IOError:print("This code caused an IOError")
except ValueError:print("This code caused an ValueError")
except:print("An error happened")
A.The conversion is completed
B.This code caused an IOError
C.An error happened
D.This code caused an ValueError
代码分析:
try: # 开始一个尝试块,用于尝试执行可能引发错误的代码x=float("abc123") # 尝试将字符串 "abc123" 转换为浮点数,这会引发 ValueError,因为 "abc123" 不是一个有效的数字print("The conversion is completed") # 如果转换成功,执行该行代码
except IOError: # 开始一个异常处理块,用于捕捉 IOError,这种错误通常与输入/输出操作有关print("This code caused an IOError") # 如果发生了 IOError,执行该行代码
except ValueError: # 开始另一个异常处理块,用于捕捉 ValueError,这种错误通常发生在某些操作或函数接收到不合适的值print("This code caused an ValueError") # 因为尝试转换一个非数字字符串abc123为浮点数,这行代码块将被执行
except: # 这是一个通用异常处理块,它会捕捉所有类型的错误print("An error happened") # 如果有任何类型的错误发生,这行代码会执行
这段Python代码展示了异常处理的基本结构,并且Python中的异常处理是按照从上到下的顺序进行的。
在执行这段代码时,因为 "abc123" 不能被转换为浮点数,所以会发生 `ValueError`,因此 `except ValueError:` 块会被触发,执行打印 "This code caused an ValueError",即选项D。
2.下面程序输入是1时,输出是什么?
def func(a):if a==0:raise ValueErrorelif a==1:raise ZeroDivisionErrori=int(input())
try:func(i)print("ok")
except Exception as e:print(type(e))
A.ok
B.<class 'ZeroDivisionError'>
C<class 'ValueError'>
D.以上都不是
代码分析:这段代码演示了如何使用异常处理机制捕获并处理不同类型的异常。
def func(a): # 定义一个名为 func 的函数,参数为 aif a == 0: # 判断 a 是否等于 0raise ValueError # 如果 a 等于 0,抛出 ValueError 异常elif a == 1: # 判断 a 是否等于 1raise ZeroDivisionError # 如果 a 等于 1,抛出 ZeroDivisionError 异常i = int(input()) # 从标准输入读取一个整数并赋值给变量 i
try: # 尝试执行以下代码块func(i) # 调用 func 函数,传入参数 iprint("ok") # 如果 func 没有抛出异常,打印 "ok"
except Exception as e: # 捕获所有继承自 Exception 的异常,并将异常实例赋值给变量 eprint(type(e)) # 打印异常的类型
由于输入是1,代码运行过程如下
i = int(input()) # 输入1,i 的值为1try:func(i) # 调用 func(1),进入 func 函数# 进入 func 函数# a == 1,因此抛出 ZeroDivisionError 异常
except Exception as e:print(type(e)) # 捕获到 ZeroDivisionError,打印 <class 'ZeroDivisionError'>
所以输出<class 'ZeroDivisionError'>,即选项B
三、填空题
1.Python内置函数______ 用来打开文件。
open
- open函数用法:
open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)
- 参数:
file
:要打开的文件的名称或路径。mode
:文件打开模式,如只读 ('r'
)、写入 ('w'
)、追加 ('a'
)、二进制模式 ('b'
) 等。buffering
、encoding
、errors
、newline
等参数用于控制文件的读取和写入方式。- 返回值:文件对象,可以对其进行读写操作。
- 例如👇
# 打开一个文件进行读取 with open('example.txt', 'r') as file:content = file.read()print(content)
2.Python内置函数open 用_____打开文件表示写模式。
w
- 文件打开模式:
'r'
:只读模式(默认)。'w'
:写模式。如果文件存在,会先清空文件内容。如果文件不存在,会创建新文件。'a'
:追加模式。如果文件存在,写入的数据会追加到文件末尾。'b'
:二进制模式。't'
:文本模式(默认)。'x'
:排他性创建模式。如果文件已存在,会引发FileExistsError
。'+'
:读写模式。- 例如👇
# 打开一个文件进行写入 with open('example.txt', 'w') as file:file.write('Hello, World!')
3.Pandas模块用____函数打开Excel文件。
read_excel
Pandas
read_excel
函数:
- 用法:
pd.read_excel(io, sheet_name=0, header=0, names=None, index_col=None, usecols=None, ... )
- 参数:
io
:文件路径、URL、文件类对象等。sheet_name
:要读取的工作表的名称或索引,默认读取第一个工作表。- 其他参数用于控制读取的数据格式和细节。
- 例如👇
import pandas as pd# 从 Excel 文件中读取数据 df = pd.read_excel('example.xlsx', sheet_name='Sheet1') print(df.head())
4.Pandas模块用函数______把数据写入CSV文件。
to_csv
Pandas
to_csv
函数:
- 用法:
DataFrame.to_csv(path_or_buf=None, sep=',', na_rep='', float_format=None, ... )
- 参数:
path_or_buf
:文件路径或对象。sep
:字段分隔符,默认为逗号。- 其他参数用于控制输出格式和细节。
- 例如👇
import pandas as pd# 创建示例 DataFrame df = pd.DataFrame({'Name': ['Alice', 'Bob', 'Charlie'],'Age': [25, 30, 35] })# 将 DataFrame 写入 CSV 文件 df.to_csv('example.csv', index=False)
5.Plotly用参数________把数据存为HTML文件。
write_html
Plotly
write_html
参数:
- 用法:
figure.write_html(file, auto_open=False, ... )
- 参数:
file
:文件路径或对象。auto_open
:是否在写入后自动打开生成的 HTML 文件。- 例如👇
import plotly.express as px# 创建示例图表 fig = px.line(x=[1, 2, 3], y=[1, 4, 9], title='Example Plot')# 将图表保存为 HTML 文件 fig.write_html('example.html')
6.下面程序的输出是____(字符串不要加引号)
try:x = float("abc123")print("数据类型转换完成")
except IOError:print("This code caused an IOError")
except ValueError:print("This code caused an ValueError")
与单选第一题是一样的 会输出This code caused an ValueError
即"abc123"
不是一个有效的浮点数表示,所以 float("abc123")
会引发一个 ValueError
异常,except ValueError:
块会被执行。
7.下面程序输入是 -3 时,输出是____
def area(r):assert r>=0,"参数错误,半径小于0"s=3.14159*r*rreturn sr=float(input())
try:print(area(r))
except AssertionError as msg:print(msg)
会输出 参数错误,半径小于0
代码分析:
def area(r):assert r >= 0, "参数错误,半径小于0" # 断言 r 必须大于等于 0,否则引发 AssertionErrors = 3.14159 * r * r # 计算圆的面积return sr = float(input()) # 从用户输入中读取半径值,并转换为浮点数
try:print(area(r)) # 尝试计算并打印圆的面积
except AssertionError as msg:print(msg) # 如果发生 AssertionError,打印错误信息
输入-3时,代码运行情况如下
r = float(input())
读取输入并将其转换为浮点数-3.0
。- 调用
print(area(r))
:
area(-3.0)
进入函数area(r)
,断言r >= 0
失败,因为r
为-3.0
。- 引发
AssertionError
,并附带错误消息"参数错误,半径小于0"
。- 异常被捕获到
except AssertionError as msg
块中,并打印错误信息msg
。
未经允许 不得转载
相关文章:
浙大版PTA Python程序设计 题目与知识点整理(综合版)
目录 第一章 一、高级语言程序的执行方式 二、变量赋值与内存地址 三、字符编码 3.1 Unicode 3.2 ASCII(American Standard Code for Information Interchange) 四、编程语言分类按照编程范式分类 4.1 面向过程语言 4.2 面向对象语言 五、原码…...
HTML表单深度解析:构建互动的网页界面
表单是HTML中用于收集用户输入信息的重要元素,是网页与用户交互的关键组件。以下是一个典型的HTML表单示例,我们将会详细解析其中的各个元素及属性含义。 <form action"https://xx.xxx.xx/search" target"_self" method"ge…...
git 分支管理规范
分支命名 master 分支 master 为主分支,也是用于部署生产环境的分支,需要确保master分支稳定性。master 分支一般由 release 以及 hotfix 分支合并,任何时间都不能直接修改代码。 develop 分支 develop 为开发环境分支,始终保持…...
Spring Cloud Gateway 详解:构建高效的API网关解决方案
Spring Cloud Gateway 详解:构建高效的API网关解决方案 Spring Cloud Gateway 是 Spring Cloud 生态系统中用于构建 API 网关的核心组件。它基于 Spring WebFlux 构建,旨在提供简单且有效的方式来路由和增强 API 请求。以下是 Spring Cloud Gateway 的详…...
基于Quartus Prime18.1的安装与FPGA的基础仿真教程
Quartus是一种美国科技公司Intel(英特尔)公司开发的FPGA(现场可编辑门阵列)设计编译软件,用作设计、仿真、综合和布局、支持多种编程语言,包括VHDL、Verilog等,并具有丰富的功能和工具库&#x…...
AJAX 和 XML:现代 Web 开发的关键技术
AJAX 和 XML:现代 Web 开发的关键技术 引言 在当今的 Web 开发领域,AJAX 和 XML 是两项至关重要的技术。AJAX(Asynchronous JavaScript and XML)允许网页在不重新加载整个页面的情况下,与服务器交换数据和更新部分网页内容。而 XML(eXtensible Markup Language)则是一…...
vue实现图片预览
在 Vue 中实现图片预览功能,通常涉及监听文件输入的变化,并在用户选择文件后,使用 FileReader API 来读取文件内容,然后显示这个内容作为图片的预览。以下是一个简单的 Vue 组件示例,它实现了图片预览功能:…...
C语言入门系列:流程控制
一,C代码执行顺序 默认情况下,C语言程序从main()函数开始执行,随后按源代码中语句出现的顺序逐一执行。 这意味着,如果不考虑任何控制结构,程序会自上而下,逐行执行每条语句,直到遇到函数调用…...
【深度学习】NLP,Transformer讲解,代码实战
文章目录 1. 前言2. Transformer结构训练过程1. 输入嵌入和位置编码2. 编码器层2.1 单头的注意力机制(便于理解)2.2 多头的注意力机制(Transformer真实使用的)2.3 残差连接和层归一化2.4 前馈神经网络(FFN)2.5 残差连接和层归一化2.6 总结 3. 解码器层 推…...
ES6 .entries用法
.entries() 返回数组的可迭代对象itarator,可以通过for of 来遍历数组或对象的值。但是它们的写法不一样。 数组用法 obj [apple,bananer,orange] for(let [i,v] of obj.entries()){console.log(i)console.log(v) } //输出 // 0 // apple // 1 // bananer // 2 //orange对象…...
【LeetCode 动态规划】买卖股票的最佳时机问题合集
文章目录 1. 买卖股票的最佳时机含冷冻期 1. 买卖股票的最佳时机含冷冻期 题目链接🔗 🍎题目思路: 🍎题目代码: class Solution { public:int maxProfit(vector<int>& prices) {int n prices.size();ve…...
python学习:语法(2)
目录 对象的布尔值 分支结构 双分支结构 多分支结构 嵌套if的使用 条件表达式 Pass语句 range()函数的使用 流程控制语句 对象的布尔值 Python一切皆对象,所有对象都有一个布尔值,通过内置函数bool()获取对象的布尔值 这些…...
经典电源电路基础(变压-整流-滤波-稳压)
1.电源电路的功能和组成 电子电路中的电源一般是低压直流电,先把220v交流电变换成低压直流电,再用整流电路变成脉动的直流电,最后用滤波电路滤除掉脉动直流中的交流成分后才能得到直流电。有的电子设备对电源的质量要求很高,所以…...
生成式人工智能备案办理指南,深度解析大模型备案全流程
早在2023年年初,国家互联网信息办公室、工业和信息化部、公安部针对深度合成服务制定的《互联网信息服务深度合成管理规定》(“《深度合成管理规定》”)顺利施行,其明确了深度合成服务相关方的义务与主体责任,强化了对…...
1527. 患某种疾病的患者
1527. 患某种疾病的患者 题目链接:1527. 患某种疾病的患者 代码如下: # Write your MySQL query statement below select patient_id,patient_name,conditions from Patients where conditions like "DIAB1%" or conditions like "% DI…...
【C/C++】【学生成绩管理系统】深度剖析
可接各类C/C管理系统课设 目录 实现功能 部分1:系统设置和主菜单 1. 引入头文件 2. 定义结构体 3. 函数声明 4. 主函数 部分2:添加学生信息 部分3:删除学生信息 部分4:修改学生信息 部分5:查询学生信息 部分…...
C++作业第四天
#include <iostream> using namespace std; class Per { private: string name; int age; int *high; double *weight; public: //构造函数 Per() { cout << "Per的无参构造" << endl; } Per(str…...
设计模式之工厂方法模式(Factory Method Pattern)
目录 1.1、前言1.2、工厂方法模式简介1.2.1、工厂方法模式的主要特点1.2.2、工厂方法模式的主要结构1.2.3、使用工厂方法模式的好处 1.3、SpringBoot中那些场景使用了工厂方法模式1.4、日常工作中那些业务场景可以使用工厂方法模式1.5、工厂方法模式实战(以某商场一…...
API接口设计的18条规范
API接口设计的18条规范 签名 目的:防止数据被篡改 实现方法: 接口请求方将请求参数、时间戳和密钥拼接成一个字符串使用MD5等hash算法生成签名sign在请求参数或请求头中增加sign参数,传递给API接口API接口网关服务验证传递的sign值&#…...
adb简单使用命令
1. 查看当前连接的设备 adb devices 2. 文件路径 adb install apk 注意文件路径中不能有中文 3. adb shell ps Toplogcatlogcat可以结合greplogcat *:w 显示警告级别以上de 4. adb uninstall 软件名 1.软件名如何查看? 使用命令adb shell pm list packages会…...
构建 deno/fresh 的 docker 镜像
众所周知, 最近 docker 镜像的使用又出现了新的困难. 但是不怕, 窝们可以使用曲线救国的方法: 自己制作容器镜像 ! 下面以 deno/fresh 举栗, 部署一个简单的应用. 目录 1 创建 deno/fresh 项目2 构建 docker 镜像3 部署和测试4 总结与展望 1 创建 deno/fresh 项目 执行命令…...
数据库 | 数据库设计的步骤
1.需求分析 调查机构情况与熟悉业务活动,明确用户的需求,确定系统的边界,生成数据字典和用户需求规格说明书 2.概念结构设计 将从需求分析中得到的用户需求抽象为概念模型,设计E-R模型 3.逻辑结构设计 将E-R图转换为和DBMS相…...
改进YOLO系列 | CVPR 2021 | Involution:超越convolution和self-attention的神经网络算子
Involution:超越卷积和自注意力的新型神经网络算子(中文综述) 简介 Involuton是CVPR 2021上提出的新型神经网络算子,旨在超越卷积和自注意力,提供更高效、更具表达力的特征提取能力。 Involution原理 Involution的…...
落地速度与效果之争,通用VS垂直,我的观点和预测。
标题:AI大模型战场:通用VS垂直,谁将领跑落地新纪元? 摘要:随着人工智能技术的飞速发展,大模型的应用场景日益广泛。在这场竞赛中,通用大模型和垂直大模型各有优势,落地速度和可能性也…...
【Android面试八股文】在Android中,出现ClassNotFound的有可能的原因是什么?
在Android环境下类未找到的可能原因 在Android环境下,类未找到的可能原因包括但不限于以下几点: 类路径问题:Android应用使用的类通常存储在APK文件中。如果类所在的APK文件没有被正确加载,或者应用的类路径配置有误,就会导致类未找到的错误。 多DEX文件加载问题:在一些…...
模板引擎与 XSS 防御
在 View 层,可以解决 XSS 问题。在本书的“跨站脚本攻击”一章中,阐述了“输入检查” 与“输出编码”这两种方法在 XSS 防御效果上的差异。XSS 攻击是在用户的浏览器上执行的, 其形成过程则是在服务器端页面渲染时,注入了恶意的 H…...
vue3轮播图怎么做
先看效果 实现代码 <n-carouseleffect"card"dot-type"line"draggable:autoplay"!isHovered":current-index"currentIndex"prev-slide-style"transform: translateX(-150%) translateZ(-450px);opacity:1"next-slide-st…...
ubuntu中安装docker并换源
使用 Ubuntu 的仓库安装 Docker sudo apt update现在,你可以使用以下命令在 Ubuntu 中安装 Docker 以及 Docker Compose: sudo apt install docker.io docker-composeDocker 包被命名为 docker.io,因为在 Docker 出现之前就已经存在一个名为…...
HTML静态网页成品作业(HTML+CSS)—— 环保主题介绍网页(5个页面)
🎉不定期分享源码,关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 🏷️本套采用HTMLCSS,未使用Javacsript代码,共有5个页面。 二、作品演示 三、代…...
深入了解RSA加密算法
目录 前言 一、什么是RSA? 二、RSA加密的基本概念 1.非对称加密 2.密钥生成 3.加密和解密 三、RSA加密的工作原理 四、RSA的应用场景 五、RSA加密解密的实现 六、RSA算法的局限性及改进措施 前言 在当今的数字化时代,信息的安全性成为了人们关注…...
哪个购物网站最便宜/设计一个公司网站多少钱
周虎摘 要:JWT(JsonWebToken)认证作为一种服务器端无状态验证方式,在分布式开发中得到了广泛的应用。但是,由于token信息的本身特点,支持的有效时间是固定的,当在token有效时间内用户操作没有完成,操作就会…...
公司网站主机流量30g每月够用吗/小企业广告投放平台
2019独角兽企业重金招聘Python工程师标准>>> 在某些状况下,类内成员变量需要动态开辟堆内存,如果实行位拷贝,也就是把对象里的值完全复制给另一个对象,如AB。这时,如果B中有一个成员变量指针已经申请了内存…...
wordpress去掉google字体/武汉seo创造者
同学毕业设计做了一个Online Judge,应该是河海第一个自主的OJ雏形了,放在github上,我也凑了个热闹。 久闻git大名,一直没用过,昨天捣鼓了一下,几个比较不错的资料如下: 关于git: http://prog…...
wordpress 自动分享/宁波seo运营推广平台排名
一、 Hibernate介绍 Hibernate是基于对象/关系映射(ORM,Object/Relational Mapping)的一个解决方案。ORM方案的思想是将对象模型表示的对象映射到关系型数据库中,或者反之。Hibernate目前是ORM思想在Java中最成功、最强大的实现。…...
济宁教育平台网站建设/公司建网站需要多少钱
1.字符串用引号括起来的就是字符串,包括单双引号name "what is your name?"print(name.title()) //title函数输出字符串首字母大写print(name.upper()) //全部大写print(name.lower()) //全部小写 2.合并(链接)字符串 first_name…...
商丘做网站优化/分销渠道
https://blog.csdn.net/sidely/article/details/43059795 xrandr --output VGA --auto --output LVDS --off 打开外接显示器,同时关闭笔记本液晶屏幕(只用外接显示器工作) xrandr --output VGA --off --output LVDS --auto 关闭外接显示器…...