值得收藏的30道Python练手题(附详解)_python题库,2024年最新蚂蚁金服内推四面

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Python全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img



既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Python知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注Python)
img

正文


### 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 True
return False

print(test())

结果:
True


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



def test():
message = ‘hi how are you hello world, hello yoyo!’
world = ‘hello’

return message.find(world)

print(test())

结果:
15


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



def test(string, str):
# 定义 last_position 初始值为 -1
last_position = -1
while True:
position = string.find(str, last_position+1)
if position == -1:
return last_position
last_position = position

print(test(‘hi how are you hello world, hello yoyo!’, ‘hello’))

结果:
28


**在学习python中有任何困难不懂的可以加入python交流学习描下方CSDN官方认证二维码  
 多多交流问题,互帮互助,这里有不错的学习教程和开发工具。**  
 ![](https://img-blog.csdnimg.cn/0b4e12ce755a46d2a0d6502e8ed1a507.png#pic_center)  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/4b9713d789114a5085f6985755a0017a.jpeg#pic_center)


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



while True:
try:
# 判断输入是否为整数
num = int(input(‘输入一个整数:’))
# 不是纯数字需要重新输入
except ValueError:
print(“输入的不是整数!”)
continue
if 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 = 0
if s[:1]’ ':
s = s[1:]
flag = 1
if s[-1:] == ’ ':
s = s[:-1]
flag = 1
if flag
1:
return trim(s)
else:
return s
print(trim(’ Hello world! '))


通过 while 循环实现:



def trim(s):
while(True):
flag = 0
if s[:1]’ ':
s = s[1:]
flag = 1
if s[-1:] == ’ ':
s = s[:-1]
flag = 1
if flag
0:
break
return 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. 打印出如下图案(菱形):  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/8b1dfb19c065441b9f2b3dcb0a3d8433.png)



def test():
n = 8
for 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 = 0
        while num != 0:
            # 判断当 num 不为 0 的时候,则每次都除以10取整
            length += 1
            num = int(num) // 10
        if length > 5:
            return "请输入正确的数字"
        return length
    except 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 = 13 + 53 + 33,因此 153 就是一个水仙花数。那么如何求 1000 以内的水仙花数(3 位数)。



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

test()


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



i = 1
for j in range(101):
i = j + i

print(i)

结果:
5051


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_all

if name == ‘main’:
result = test(sum_to=100)
print(result)

-50


22. 现有计算公式 13 + 23 + 33 + 43 + …….+ n3,如何实现:当输入 n = 5 时,输出 225(对应的公式 : 13 + 23 + 33 + 43 + 53 = 225)。



def test(n):
sum = 0
for i in range(1, n+1):
sum += i*10+i
return 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 True
return False

print(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 = 0
for i in a:
# 判断每循环列表中的一个数据,则计数器中会 +1
count += 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]

  1. 找出列表 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


27.上面是通过 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]

在这里插入图片描述

感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的:

① 2000多本Python电子书(主流和经典的书籍应该都有了)

② Python标准库资料(最全中文版)

③ 项目源码(四五十个有趣且经典的练手项目及源码)

④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)

⑤ Python学习路线图(告别不入流的学习)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注python)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
w_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3poaWd1aWd1,size_16,color_FFFFFF,t_70)

感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的:

① 2000多本Python电子书(主流和经典的书籍应该都有了)

② Python标准库资料(最全中文版)

③ 项目源码(四五十个有趣且经典的练手项目及源码)

④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)

⑤ Python学习路线图(告别不入流的学习)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注python)
[外链图片转存中…(img-7c5dY2yM-1713233729220)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值