值得收藏的30道Python基础练手题(附详解)

article/2025/9/19 17:32:34

今天给大家分享30道Python练习题,建议大家先独立思考一下解题思路,再查看答案。

1. 已知一个字符串为 “hello_world_JMzz”,如何得到一个队列 

[“hello”,”world”,”JMzz”] ?

使用 split 函数,分割字符串,并且将数据转换成列表类型:

test = 'hello_world_JMzz'
print(test.split("_"))

结果:

['hello', 'world', 'JMzz']

2. 有个列表 [“hello”, “world”, “JMzz”],如何把列表里面的字符串联起来,得到字符串 “hello_world_JMzz”?

使用 join 函数将数据转换成字符串:

test = ["hello", "world", "JMzz"]
print("_".join(test))

结果:

hello_world_JMzz

如果不依赖 python 提供的 join 方法,还可以通过 for 循环,然后将字符串拼接,但是在用“+”连接字符串时,结果会生成新的对象,使用 join 时结果只是将原列表中的元素拼接起来,所以 join 效率比较高。

for 循环拼接如下:

test = ["hello", "world", "JMzz"]
# 定义一个空字符串
j = ''
# 通过 for 循环打印出列表中的数据
for i in test:j = j + "_" + i
# 因为通过上面的字符串拼接,得到的数据是“_hello_world_JMzz”,前面会多一个下划线_,所以把这个下划线去掉
print(j.lstrip("_"))

3. 把字符串 s 中的每个空格替换成”%20”,输入:s = “We are happy.”,输出:“We%20are%20happy.”。

使用 replace 函数,替换字符换即可:

s = 'We are happy.'
print(s.replace(' ', '%20'))

结果:

We%20are%20happy.

4. Python 如何打印 99 乘法表?

for 循环打印:

for i in range(1, 10):for j in range(1, i+1):print('{}x{}={}\t'.format(j, i, i*j), end='')print()

while 循环实现:

i = 1
while i <= 9:j = 1while j <= i:print("%d*%d=%-2d"%(i,j,i*j),end = ' ')  # %d: 整数的占位符,'-2'代表靠左对齐,两个占位符j += 1print()i += 1

结果:

1x1=1 
1x2=2 2x2=4 
1x3=3 2x3=6 3x3=9 
1x4=4 2x4=8 3x4=12 4x4=16 
1x5=5 2x5=10 3x5=15 4x5=20 5x5=25 
1x6=6 2x6=12 3x6=18 4x6=24 5x6=30 6x6=36 
1x7=7 2x7=14 3x7=21 4x7=28 5x7=35 6x7=42 7x7=49 
1x8=8 2x8=16 3x8=24 4x8=32 5x8=40 6x8=48 7x8=56 8x8=64 
1x9=9 2x9=18 3x9=27 4x9=36 5x9=45 6x9=54 7x9=63 8x9=72 9x9=81

5. 从下标 0 开始索引,找出单词 “welcome” 在字符串“Hello, welcome to my world.” 中出现的位置,找不到返回 -1。

def test():message = 'Hello, welcome to my world.'world = 'welcome'if world in message:return message.find(world)else:return -1print(test())结果:
7

6. 统计字符串“Hello, welcome to my world.” 中字母 w 出现的次数。

def test():message = 'Hello, welcome to my world.'# 计数num = 0# for 循环 messagefor i in message:# 判断如果 ‘w’ 字符串在 message 中,则 num +1if 'w' in i:num += 1return numprint(test())
# 结果
2

7. 输入一个字符串 str,输出第 m 个只出现过 n 次的字符,如在字符串 gbgkkdehh 中,找出第 2 个只出现 1 次的字符,输出结果:d

def test(str_test, num, counts):""":param str_test: 字符串:param num: 字符串出现的次数:param count: 字符串第几次出现的次数:return:"""# 定义一个空数组,存放逻辑处理后的数据list = []# for循环字符串的数据for i in str_test:# 使用 count 函数,统计出所有字符串出现的次数count = str_test.count(i, 0, len(str_test))# 判断字符串出现的次数与设置的counts的次数相同,则将数据存放在list数组中if count == num:list.append(i)# 返回第n次出现的字符串return list[counts-1]print(test('gbgkkdehh', 1, 2))
结果:
d

8. 判断字符串 a = “welcome to my world” 是否包含单词 b = “world”,包含返回 True,不包含返回 False。

def test():message = 'welcome to my world'world = 'world'if world in message:return Truereturn Falseprint(test())结果:
True

9. 从 0 开始计数,输出指定字符串 A = “hello” 在字符串 B = “hi how are you hello world, hello JMzz!”中第一次出现的位置,如果 B 中不包含 A,则输出 -1。

def test():message = 'hi how are you hello world, hello JMzz!'world = 'hello'return message.find(world)print(test())结果:
15

10. 从 0 开始计数,输出指定字符串 A = “hello”在字符串 B = “hi how are you hello world, hello JMzz!”中最后出现的位置,如果 B 中不包含 A,则输出 -1。

def test(string, str):# 定义 last_position 初始值为 -1last_position = -1while True:position = string.find(str, last_position+1)if position == -1:return last_positionlast_position = positionprint(test('hi how are you hello world, hello JMzz!', 'hello'))结果:
28

11. 给定一个数 a,判断一个数字是否为奇数或偶数。

while True:try:# 判断输入是否为整数num = int(input('输入一个整数:'))# 不是纯数字需要重新输入except ValueError: print("输入的不是整数!")continueif num % 2 == 0:print('偶数')else:print('奇数')break结果:
输入一个整数:100
偶数

12. 输入一个姓名,判断是否姓王。

def test():user_input = input("请输入您的姓名:")if user_input[0] == '王':return "用户姓王"return "用户不姓王"print(test())结果:
请输入您的姓名:王总
用户姓王

13. 如何判断一个字符串是不是纯数字组成?

利用 Python 提供的类型转行,将用户输入的数据转换成浮点数类型,如果转换抛异常,则判断数字不是纯数字组成。

def test(num):try:return float(num)except ValueError:return "请输入数字"print(test('133w3'))

14. 将字符串 a = “This is string example….wow!” 全部转成大写,字符串 b = “Welcome To My World” 全部转成小写。

a = 'This is string example….wow!'
b = 'Welcome To My World'print(a.upper())
print(b.lower())

15. 将字符串 a = “ welcome to my world ”首尾空格去掉

Python 提供了strip() 方法,可以去除首尾空格,rstrip() 去掉尾部空格,lstrip() 去掉首部空格,replace(" ", “”) 去掉全部空格。

a = '  welcome to my world   '
print(a.strip())

还可以通过递归的方式实现:

def trim(s):flag = 0if s[:1]==' ':s = s[1:]flag = 1if s[-1:] == ' ':s = s[:-1]flag = 1if flag==1:return    trim(s)else:return s
print(trim('  Hello world!  '))

通过 while 循环实现:

def trim(s):while(True):flag = 0if s[:1]==' ':s = s[1:]flag = 1if s[-1:] == ' ':s = s[:-1]flag = 1if flag==0:breakreturn s
print(trim('  Hello world!  '))

16. 将字符串 s = “ajldjlajfdljfddd”,去重并从小到大排序输出”adfjl”。

def test():s = 'ajldjlajfdljfddd'# 定义一个数组存放数据str_list = []# for循环s字符串中的数据,然后将数据加入数组中for i in s:# 判断如果数组中已经存在这个字符串,则将字符串移除,加入新的字符串if i in str_list:str_list.remove(i)str_list.append(i)# 使用 sorted 方法,对字母进行排序a = sorted(str_list)# sorted方法返回的是一个列表,这边将列表数据转换成字符串return "".join(a)print(test())结果:
adfjl

17. 打印出如下图案(菱形):

def test():n = 8for i in range(-int(n/2), int(n/2) + 1):print(" "*abs(i), "*"*abs(n-abs(i)*2))print(test())结果:********************************

18.  给一个不多于 5 位的正整数(如 a = 12346),求它是几位数和逆序打印出各位数字。

class Test:# 计算数字的位数def test_num(self, num):try:# 定义一个 length 的变量,来计算数字的长度length = 0while num != 0:# 判断当 num 不为 0 的时候,则每次都除以10取整length += 1num = int(num) // 10if length > 5:return "请输入正确的数字"return lengthexcept ValueError:return "请输入正确的数字"# 逆序打印出个位数def test_sorted(self, num):if self.test_num(num) != "请输入正确的数字":# 逆序打印出数字sorted_num = num[::-1]# 返回逆序的个位数return sorted_num[-1]print(Test().test_sorted('12346'))结果:
1

19. 如果一个 3 位数等于其各位数字的立方和,则称这个数为水仙花数。例如:153 = 1³ + 5³ + 3³,因此 153 就是一个水仙花数。那么如何求 1000 以内的水仙花数(3 位数)。

def test():for num in range(100, 1000):i = num // 100j = num // 10 % 10k = num % 10if i ** 3 + j ** 3 + k ** 3 == num:print(str(num) + "是水仙花数")
test()

20. 求 1+2+3…+100 相加的和。

i = 0
for j in range(101):i = j + iprint(i)结果:
5050

21. 计算 1-2+3-4+5-…-100 的值。

def test(sum_to):# 定义一个初始值sum_all = 0# 循环想要计算的数据for i in range(1, sum_to + 1):sum_all += i * (-1) ** (1 + i)return sum_allif __name__ == '__main__':result = test(sum_to=100)print(result)-50

22. 现有计算公式 1³ + 2³ + 3³ + 4³ + …….+ n³,如何实现:当输入 n = 5 时,输出 225(对应的公式 : 1³ + 2³ + 3³ + 4³ + 5³ = 225)。

def test(n):sum = 0for i in range(1, n+1):sum += i*10+ireturn sum
print(test(5))
结果:
225

23. 已知 a 的值为“hello”,b 的值为“world”,如何交换 a 和 b 的值,得到 a 的值为“world”,b 的值为”hello”?

a = 'hello'
b = 'world'c = a
a = b
b = c
print(a, b)

24. 如何判断一个数组是对称数组?

例如 [1,2,0,2,1],[1,2,3,3,2,1],这样的数组都是对称数组。用 Python 判断,是对称数组打印 True,不是打印 False。

def test():x = [1, 'a', 0, '2', 0, 'a', 1]# 通过下标的形式,将字符串逆序进行比对if x == x[::-1]:return Truereturn Falseprint(test())结果:
True

25. 如果有一个列表 a = [1,3,5,7,11],那么如何让它反转成 [11,7,5,3,1],并且取到奇数位值的数字 [1,5,11]?

def test():a = [1, 3, 5, 7, 11]# 逆序打印数组中的数据print(a[::-1])# 定义一个计数的变量count = 0for i in a:# 判断每循环列表中的一个数据,则计数器中会 +1count += 1# 如果计数器为奇数,则打印出来if count % 2 != 0:print(i)test()结果:
[11, 7, 5, 3, 1]
1
5
11

26. 对列表 a = [1, 6, 8, 11, 9, 1, 8, 6, 8, 7, 8] 中的数字从小到大排序。

a = [1, 6, 8, 11, 9, 1, 8, 6, 8, 7, 8]
print(sorted(a))结果:
[1, 1, 6, 6, 7, 8, 8, 8, 8, 9, 11]

27. 找出列表 L1 = [1, 2, 3, 11, 2, 5, 3, 2, 5, 33, 88] 中最大值和最小值。

L1 = [1, 2, 3, 11, 2, 5, 3, 2, 5, 33, 88]
print(max(L1))
print(min(L1))结果:
88
1

上面是通过 Python 自带的函数实现,如下,可以自己写一个计算程序:

class Test(object):def __init__(self):# 测试的列表数据self.L1 = [1, 2, 3, 11, 2, 5, 3, 2, 5, 33, 88]# 从列表中取第一个值,对于数据大小比对self.num = self.L1[0]def test_small_num(self, count):""":param count: count为 1,则表示计算最大值,为 2 时,表示最小值:return:"""# for 循环查询列表中的数据for i in self.L1:if count == 1:# 循环判断当数组中的数据比初始值小,则将初始值替换if i > self.num:self.num = ielif count == 2:if i < self.num:self.num = ielif count != 1 or count != 2:return "请输入正确的数据"return self.numprint(Test().test_small_num(1))
print(Test().test_small_num(2))
结果:
88
1

28. 找出列表 a = [“hello”, “world”, “JMzz”, “congratulations”] 中单词最长的一个。

def test():a = ["hello", "world", "JMzz", "congratulations"]# 统计数组中第一个值的长度length = len(a[0])for i in a:# 循环数组中的数据,当数组中的数据比初始值length中的值长,则替换掉length的默认值if len(i) > length:length = ireturn lengthprint(test())结果:
congratulations

29. 取出列表 L1 = [1, 2, 3, 11, 2, 5, 3, 2, 5, 33, 88] 中最大的三个值。

def test():L1 = [1, 2, 3, 11, 2, 5, 3, 2, 5, 33, 88]return sorted(L1)[:3]print(test())结果:
[88, 33, 11]

30. 把列表 a = [1, -6, 2, -5, 9, 4, 20, -3] 中的数字绝对值。

def test():a = [1, -6, 2, -5, 9, 4, 20, -3]# 定义一个数组,存放处理后的绝对值数据lists = []for i in a:# 使用 abs() 方法处理绝对值lists.append(abs(i))return listsprint(test())结果:
[1, 6, 2, 5, 9, 4, 20, 3]

 


http://chatgpt.dhexx.cn/article/J9ckAcwY.shtml

相关文章

入门Python必备100道练习题

给大家整理了这份今天给大家分享100道Python练习题。 在此之前&#xff0c;先给大家推荐一个工具&#xff0c;是一个对 Python 运行原理进行可视化分析的工具&#xff0c;Python Tutor&#xff0c; 点击 Next 按钮就会根据执行步骤显示原理&#xff0c;对新手理解代码运行原理…

值得收藏的25道Python练手题(附详细答案)

来源丨吾爱破解 题目 1&#xff1a;水仙花数 水仙花数&#xff08;Narcissistic number&#xff09;也被称为超完全数字不变数&#xff08;pluperfect digital invariant, PPDI&#xff09;、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数&#xff08;Armstrong number&#xff09…

值得苦练的100道Python经典练手题,(附详细答案)

嗨喽大家好卷子又来了&#xff0c;100道Python经典练手题奉上 花了一周的时间&#xff0c;整理了100道Python的练习题&#xff0c;如果你是一位初学者&#xff0c;那么这一份练习题将会给你带来极大的帮助&#xff0c;如果你能够完全独立的完成这份练习题&#xff0c;你已经入…

经典论文-SeNet论文及实践

Squeeze-and-Excitation Networks 作者&#xff1a;Jie Hu, Li Shen&#xff0c; Samuel Albanie&#xff0c; Gang Sun, Enhua Wu单位&#xff1a; Chinese Academy of Sciences论文地址&#xff1a; https://arxiv.org/pdf/1709.01507.pdf项目地址&#xff1a;https://githu…

SENet双塔模型:在推荐领域召回粗排的应用及其它

目前&#xff0c;双塔结构在推荐领域里已经是个常规方法了&#xff0c;在召回和粗排环节的模型选型中&#xff0c;被广泛采用。其实&#xff0c;不仅仅是在推荐领域&#xff0c;在其它领域&#xff0c;双塔结构也已经被越来越多得用起来了。比如&#xff0c;在当代搜索引擎的召…

SENet讲解

卷积就是在卷空间信息&#xff0c;可通道信息也大不相同&#xff0c;有的通道信息重要&#xff0c;而有点通道信息是无用的。 对特征图U的每个通道应用全局平均池化层&#xff08;avg)&#xff0c;可以得到该特征通道的常数标量。然后经过两个FC层得到C个权重系数&#xff0c;…

senet模型代码解读

网络架构图&#xff1a; 准备模型&#xff1a; model_name se_resnext101_32x4d model MODEL( num_classes 500 , senet154_weight WEIGHT_PATH, multi_scale True, learn_regionTrue) model torch.nn.DataParallel(model) vgg16 model vgg16.load_state_dict(torch.loa…

SENet(2017)

卷积核作为卷积神经网络的核心&#xff0c;通常被看作是在局部感受野上&#xff0c;将空间上&#xff08;spatial&#xff09;的信息和特征维度上&#xff08;channel-wise&#xff09;的信息进行聚合的信息聚合体。卷积神经网络由一系列卷积层、非线性层和下采样层构成&#x…

SENet

这篇文章出自《Squeeze-and-Excitation Networks》&#xff0c;在ILSVRC-2017分类挑战赛上获得了冠军。 1. 研究问题 大多数CNN都研究如何捕获特征的空间相关性来提高网络的表示能力&#xff0c;这篇文章研究的是捕获特征通道之间的相关性来提高网络性能。 2. 研究方法 提出…

SENET和GateNet(推荐系统(embedding))

SENET介绍 SENET是在论文《Squeeze-and-Excitation Networks》中提出来的&#xff0c;应用在图像处理上的。主要思想&#xff1a;通过建模channel之间的关系来矫正channel的特征&#xff0c;以此提升神经网络的表征能力。&#xff08;原文&#xff1a;adaptively recalibrates…

SENet解析

1 前言 在深度学习领域&#xff0c;CNN分类网络的发展对其它计算机视觉任务如目标检测和语义分割都起到至关重要的作用&#xff0c;因为检测和分割模型通常是构建在CNN分类网络&#xff08;称为backbone&#xff09;之上。提到CNN分类网络&#xff0c;我们所熟知的是VGG&#…

SENet详解

SENet是ImageNet 2017&#xff08;ImageNet收官赛&#xff09;的冠军模型&#xff0c;和ResNet的出现类似&#xff0c;都在很大程度上减小了之前模型的错误率&#xff08;具体见附录&#xff09;&#xff0c;并且复杂度低&#xff0c;新增参数和计算量小。下面就来具体介绍一些…

SENet概览

一、背景 在深度学习领域&#xff0c;已经有很多成果通过在空间维度上对网络的性能进行了提升。但是&#xff0c;SENet反其道而行之&#xff0c;通过对通道关系进行建模来提升网络的性能。Squeeze和Excitation是两个非常关键的操作&#xff0c;所以SENet以此来命名。SENet的动机…

深度学习理论篇之 ( 十八) -- 注意力机制之SENet

科普知识 ILSVRC&#xff08;ImageNet Large Scale Visual Recognition Challenge&#xff09;是机器视觉领域最受追捧也是最具权威的学术竞赛之一&#xff0c;代表了图像领域的最高水平。 ImageNet数据集是ILSVRC竞赛使用的是数据集&#xff0c;由斯坦福大学李飞飞教授主导&am…

【深度学习】(8) CNN中的通道注意力机制(SEnet、ECAnet),附Tensorflow完整代码

各位同学好&#xff0c;今天和大家分享一下attention注意力机制在CNN卷积神经网络中的应用&#xff0c;重点介绍三种注意力机制&#xff0c;及其代码复现。 在我之前的神经网络专栏的文章中也使用到过注意力机制&#xff0c;比如在MobileNetV3、EfficientNet网络中都是用了SE注…

[ 注意力机制 ] 经典网络模型1——SENet 详解与复现

&#x1f935; Author &#xff1a;Horizon Max ✨ 编程技巧篇&#xff1a;各种操作小结 &#x1f387; 机器视觉篇&#xff1a;会变魔术 OpenCV &#x1f4a5; 深度学习篇&#xff1a;简单入门 PyTorch &#x1f3c6; 神经网络篇&#xff1a;经典网络模型 &#x1f4bb; …

算法 雪花算法 Python

Twitter 于 2010 年开源了内部团队在用的一款全局唯一 ID 生成算法 Snowflake&#xff0c;翻译过来叫做雪花算法。Snowflake 不借助数据库&#xff0c;可直接由编程语言生成&#xff0c;它通过巧妙的位设计使得 ID 能够满足递增属性&#xff0c;且生成的 ID 并不是依次连续的。…

聊聊雪花算法?

随便聊聊 哈喽&#xff0c;大家好&#xff0c;最近换了份工作&#xff0c;虽然后端技术栈是老了点&#xff0c;但是呢&#xff0c;这边的前端技术确是现在市面上最新的那一套技术&#xff1a;Vue3ViteTSXPinaElement-PlusNativeUI。我本人主要是学后端的&#xff0c;确被拉去做…

雪花算法生成实例

雪花算法生成实例 一、集群高并发情况下如何保证分布式唯一全局id生成&#xff1f;1.1 为什么需要分布式全局唯一ID以及分布式ID的业务需求1.2 ID生成规则部分硬性要求1.3 ID号生成系统的可用性要求 二、一般通用方案2.1 UUID2.2 数据库自增主键2.3 基于Redis生成全局id策略2.4…

算法 —— 雪花算法

文章目录 算法 —— 雪花算法简介实现原理结构图 算法 —— 雪花算法 简介 雪花算法是由 Twitter 公布的分布式主键生成算法&#xff0c;它能够保证不同进程主键的不重复性&#xff0c;以及相同进程主键的有序性。 实现原理 在同一个进程中&#xff0c;它首先是通过时间位保…