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

article/2025/9/19 17:50:22

嗨喽大家好卷子又来了,100道Python经典练手题奉上

花了一周的时间,整理了100道Python的练习题,如果你是一位初学者,那么这一份练习题将会给你带来极大的帮助,如果你能够完全独立的完成这份练习题,你已经入门的Python了,练习题涵盖Python基础的大部分内容:

Python100经典练习题,附答案很多小伙伴在学习Python的时候,有时候会迷茫,不知道怎么可以检测出自己的水平是否很高,这次给大家带了这1https://mp.weixin.qq.com/s/wJKG2AsaCQxQhpK-rf2qwQ问题1

问题:

编写一个程序,查找所有此类数字,它们可以被7整除,但不能是5的倍数(在2000和3200之间(均包括在内))。获得的数字应以逗号分隔的顺序打印在一行上。

提示:

考虑使用范围(#begin,#end)方法。

我的解决方案:Python 3

  • 使用for循环

l=[]
for i in range(2000, 3201):if (i%7==0) and (i%5!=0):l.append(str(i))print ','.join(l)
  • 使用生成器和列表理解

print(*(i for i in range(2000, 3201) if i%7 == 0 and i%5 != 0), sep=",")

问题2

问题:

编写一个程序,可以计算给定数字的阶乘,结果应以逗号分隔的顺序打印在一行上,假设向程序提供了以下输入:8然后,输出应为:40320

提示:

如果将输入数据提供给问题,则应假定它是控制台输入。

我的解决方案:Python 3

  • 使用While循环
    n = int(input()) #input() function takes input as string type
    #int() converts it to integer type
    fact = 1
    i = 1
    while i <= n:
    fact = fact * i;
    i = i + 1
    print(fact)

  • 使用For循环
    n = int(input()) #input() function takes input as string type
    #int() converts it to integer type
    fact = 1
    for i in range(1,n+1):
    fact = fact * i
    print(fact)

  • 使用Lambda函数
    n = int(input())
    def shortFact(x): return 1 if x <= 1 else x*shortFact(x-1)
    print(shortFact(n))

while True:
try:num = int(input("Enter a number: "))break
except ValueError as err:print(err)org = num
fact = 1
while num:fact = num * factnum = num - 1
print(f'the factorial of {org} is {fact}')
from functools import reducedef fun(acc, item):return acc*itemnum = int(input())
print(reduce(fun,range(1, num+1), 1))

问题3

问题:

使用给定的整数n,编写程序以生成包含(i,ixi)的字典,该字典为1到n之间的整数(都包括在内)。然后程序应打印字典。假设向程序提供了以下输入:8\
然后,输出应为:
{1: 1, 2: 4, 3: 9, 4: 16, 5: 25, 6: 36, 7: 49, 8: 64}

提示:

如果将输入数据提供给问题,则应假定它是控制台输入。考虑使用dict()

我的解决方案:Python 3:

  • 使用for循环

n = int(input())
ans = {}
for i in range (1,n+1):ans[i] = i * i
print(ans)
  • 使用字典理解

n = int(input())
ans={i : i*i for i in range(1,n+1)}
print(ans)
# 演进
try:num = int(input("Enter a number: "))
except ValueError as err:print(err)dictio = dict()
for item in range(num+1):if item == 0:continueelse:dictio[item] = item * item
print(dictio)
num = int(input("Number: "))
print(dict(enumerate([i*i for i in range(1, num+1)], 1)))

这些是第一天解决的问题。对于基本的初学者学习者来说,上述问题非常容易。我在解决方案中展示了一些简单的编码方法。让我们看看第二天如何面对和应对新问题。

问题

编写一个程序,该程序接受以逗号分隔的4位二进制数字序列作为输入,然后检查它们是否可被5整除。被5整除的数字将以逗号分隔的顺序打印。
例子:
0100,0011,1010,1001
然后输出应为:
1010
注意:假设数据是通过控制台输入的。

提示:

如果将输入数据提供给问题,则应假定它是控制台输入。
def check(x):                       #转换二进制整数&返回由5零中频整除total, pw = 0, 1reversed(x)for i in x:total+=pw * (ord(i) - 48)    #ORD()函数返回ASCII值pw*=2return total % 5data = input().split(",")           #输入此处,并在','位置分割
lst = []for i in data:if check(i) == 0:              #如果零发现它是指由零整除并添加到列		lst.append(i)print(",".join(lst))

或者

def  check(x):#如果被5整除,则check函数返回true return  int(x,2)%5  ==  0       #int(x,b)将x作为字符串,将b作为基数,#将其转换为十进制
数据 = 输入()。分割(',')data  =  list(filter(check(data)))#在filter(func,object)函数中,如果通过'check'函数
print(“,”。join(data)找到True,则从'data'中选取元素。

或者

data = input().split(',')
data = [num for num in data if int(num, 2) % 5 == 0]
print(','.join(data))

问题12

问题:

编写一个程序,查找所有介于1000和3000之间的数字(都包括在内),以使数字的每个数字均为偶数。获得的数字应以逗号分隔的顺序打印在一行上。

提示:

如果将输入数据提供给问题,则应假定它是控制台输入。

我的解决方案:Python 3

lst = []for i in range(1000,3001):flag = 1for j in str(i):         #每个整数编号i被转换成字符串if ord(j)%2 != 0:     #ORD返回ASCII值并且j是iflag = 0          if flag == 1:lst.append(str(i))   #i作为字符串存储在列表中print(",".join(lst))

或者

def check(element):return all(ord(i)%2 == 0 for i in element)  #所有返回true如果所有的数字,i是即使在元件lst = [str(i) for i in range(1000,3001)]        #创建所有给定数字的列表,其字符串数据类型为
lst = list(filter(check,lst))                   #如果检查条件失败,则过滤器从列表中删除元素
print(",".join(lst))
lst = [str(i) for i in range(1000,3001)]
lst = list(filter(lambda i:all(ord(j)%2 == 0 for j in i), lst))   #使用lambda来在过滤器功能内部定义函数
print(",".join(lst))

问题13

问题:

编写一个接受句子并计算字母和数字数量的程序。
假设将以下输入提供给程序:
hello world! 123
然后,输出应为:
LETTERS 10
DIGITS 3

提示:

如果将输入数据提供给问题,则应假定它是控制台输入。
word = input()
letter,digit = 0,0for i in word:if ('a'<=i and i<='z') or ('A'<=i and i<='Z'):letter+=1if '0'<=i and i<='9':digit+=1print("LETTERS {0}\nDIGITS {1}".format(letter,digit))

或者

word = input()
letter, digit = 0,0for i in word:if i.isalpha(): #返回true如果字母表letter += 1elif i.isnumeric(): #返回true如果数字digit += 1
print(f"LETTERS {letter}\n{digits}") #两种解决方案均显示两种不同类型的格式化方法

10-13以上所有问题大多是与字符串有关的问题。解决方案的主要部分包括字符串替换函数和理解方法,以更短的形式写下代码。

问题14

问题:

编写一个接受句子的程序,并计算大写字母和小写字母的数量。
假设将以下输入提供给程序:
Hello world!
然后,输出应为:
UPPER CASE 1
LOWER CASE 9

提示:

如果将输入数据提供给问题,则应假定它是控制台输入。

我的解决方案:Python 3

word = input()
upper,lower = 0,0for i in word:if 'a'<=i and i<='z' :lower+=1if 'A'<=i and i<='Z':upper+=1print("UPPER CASE {0}\nLOWER CASE {1}".format(upper,lower))

或者

word = input()
upper,lower = 0,0for i in word:lower+=i.islower()upper+=i.isupper()print("UPPER CASE {0}\nLOWER CASE {1}".format(upper,lower))

或者

string = input("Enter the sentense")
upper = 0
lower = 0
for x in string:if x.isupper() == True:upper += 1if x.islower() == True:lower += 1print("UPPER CASE: ", upper)
print("LOWER CASE: ", lower)

Python100经典练习题,附答案很多小伙伴在学习Python的时候,有时候会迷茫,不知道怎么可以检测出自己的水平是否很高,这次给大家带了这1https://mp.weixin.qq.com/s/wJKG2AsaCQxQhpK-rf2qwQ


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

相关文章

经典论文-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;它首先是通过时间位保…

java雪花算法实现

基于雪花算法&#xff08;Snowflake&#xff09;模式雪花算法&#xff08;Snowflake&#xff09;是twitter公司内部分布式项目采用的ID生成算法&#xff0c;开源后广受国内大厂的好评&#xff0c;在该算法影响下各大公司相继开发出各具特色的分布式生成器。 Snowflake生成的是L…

雪花算法的实现原理

一位工作4年的小伙伴&#xff0c;去某东面试时被问到这样一道题&#xff0c;说请你简述一下雪花算法的实现原理。屏幕前的小伙伴&#xff0c;如果你遇到这个问题&#xff0c;你会怎么回答&#xff1f; 今天&#xff0c;我给大家分享一下我的理解。 1、什么是雪花算法 雪花算…

Python 实现雪花算法

Python 实现雪花算法 雪花算法&#xff1a;雪花算法是一种分布式全局唯一ID&#xff0c;一般不需要过多的深入了解&#xff0c;一般个人项目用不到分布式之类的大型架构&#xff0c;另一方面&#xff0c;则是因为&#xff0c;就算用到市面上很多 ID 生成器帮我们完成了这项工作…