Python小白必做的30道基础练习题(附保姆级答案解析)

这里是为 Python 真正的小白 准备的 30道超基础练习题(2026年视角),难度从输入输出 → 变量 → 条件 → 循环 → 字符串 → 列表 → 函数逐步递增。

每道题都附带:

  • 题目描述
  • 参考答案(最简单、最清晰的写法)
  • 核心知识点 + 小提示(保姆级解析)

建议做法
先自己写 10–15 分钟 → 看不懂再看答案 → 看完答案立刻自己敲一遍 → 改一改输入试试不同情况。

1–10:最基础(输入输出 + 变量 + 运算)

  1. 写一个程序,打印 “Hello, Python小白!2026加油!”
print("Hello, Python小白!2026加油!")
  1. 定义两个变量 a=10,b=3,打印它们的和、差、积、商(保留2位小数)
a =10 b =3print(a + b)# 13print(a - b)# 7print(a * b)# 30print(f"{a / b:.2f}")# 3.33
  1. 从键盘输入两个整数,计算并打印它们的乘积
x =int(input("请输入第一个数:")) y =int(input("请输入第二个数:"))print("乘积是:", x * y)
  1. 输入一个数字,判断它是奇数还是偶数
n =int(input("输入一个整数:"))if n %2==0:print("偶数")else:print("奇数")
  1. 输入身高(米)和体重(公斤),计算 BMI 并判断体型
    (BMI = 体重 / 身高²,<18.5偏瘦,18.5-23.9正常,≥24超重)
height =float(input("身高(米):")) weight =float(input("体重(kg):")) bmi = weight /(height **2)print(f"BMI = {bmi:.2f}")if bmi <18.5:print("偏瘦")elif bmi <=23.9:print("正常")else:print("超重")
  1. 输入年份,判断是否是闰年
    (能被4整除且不能被100整除,或能被400整除)
year =int(input("输入年份:"))if(year %4==0and year %100!=0)or(year %400==0):print("闰年")else:print("平年")
  1. 打印 1 到 10 的所有整数(用while和for两种方式)
# while i =1while i <=10:print(i, end=" ") i +=1print()# 换行# forfor i inrange(1,11):print(i, end=" ")
  1. 计算 1 + 2 + 3 + … + 100 的和(用for和while各写一次)
# for版 s =0for i inrange(1,101): s += i print(s)# 5050# while版 s =0 i =1while i <=100: s += i i +=1print(s)
  1. 打印九九乘法表(完整版)
for i inrange(1,10):for j inrange(1, i+1):print(f"{j}×{i}={i*j:2d}", end=" ")print()
  1. 输入一个正整数 n,打印 n 行星号三角形(第一行1个*,第二行2个…)
n =int(input("输入行数:"))for i inrange(1, n+1):print("*"* i)

11–20:字符串 + 列表基础

  1. 输入一句话,把所有空格替换成下划线 _
s =input("输入一句话:")print(s.replace(" ","_"))
  1. 输入一个字符串,统计其中字母 ‘a’ 出现的次数(不区分大小写)
s =input("输入字符串:").lower()print("a 出现了", s.count('a'),"次")
  1. 输入三个整数,用空格分隔,一行输入,存入列表并排序后输出
nums =list(map(int,input("输入三个整数,用空格隔开:").split())) nums.sort()print(nums)
  1. 有一个列表 names = [“张三”, “李四”, “王五”, “赵六”],在"王五"后面插入"孙七"
names =["张三","李四","王五","赵六"] names.insert(3,"孙七")# 或 names.insert(names.index("王五")+1, "孙七")print(names)
  1. 列表 fruits = [“apple”, “banana”, “cherry”, “apple”],删除所有 “apple”
fruits =["apple","banana","cherry","apple"] fruits =[f for f in fruits if f !="apple"]# 列表推导式最简洁# 或者:while "apple" in fruits: fruits.remove("apple")print(fruits)
  1. 产生一个包含 1–100 所有能被3整除的数的列表
lst =[i for i inrange(1,101)if i %3==0]print(lst)
  1. 输入一个字符串,反转后输出(三种方法任选)
s =input("输入:")# 方法1 最常用print(s[::-1])# 方法2print("".join(reversed(s)))# 方法3print(s[len(s)::-1])# 记住这个也行
  1. 判断一个字符串是否是回文串(正读反读一样,如 “radar”)
s =input("输入字符串:").lower().replace(" ","")# 忽略大小写和空格if s == s[::-1]:print("是回文")else:print("不是回文")
  1. 把字符串 “1,2,3,4,5” 转成列表 [1,2,3,4,5](元素是整数)
s ="1,2,3,4,5" lst =[int(x)for x in s.split(",")]print(lst)
  1. 有一个列表 scores = [89, 76, 65, 92, 58, 77],统计及格(>=60)的人数
scores =[89,76,65,92,58,77] count =sum(1for x in scores if x >=60)# 或 len([x for x in scores if x >= 60])print("及格人数:", count)

21–30:函数 + 综合小练习

  1. 写一个函数,接收两个数,返回较大的那个
defmax2(a, b):return a if a > b else b print(max2(10,25))# 25
  1. 写一个函数 is_prime(n),判断 n 是否是素数
defis_prime(n):if n <2:returnFalsefor i inrange(2,int(n**0.5)+1):if n % i ==0:returnFalsereturnTrueprint(is_prime(17))# Trueprint(is_prime(15))# False
  1. 写函数 factorial(n) 计算 n 的阶乘(5! = 120)
deffactorial(n):if n ==0or n ==1:return1 res =1for i inrange(2, n+1): res *= i return res print(factorial(5))# 120
  1. 写函数 sum_of_list(lst),返回列表中所有元素的和
defsum_of_list(lst):returnsum(lst)# 最简单# 或者自己写循环# s = 0# for x in lst: s += x# return s
  1. 写一个函数,接收一个整数 n,打印 1 到 n 的斐波那契数列(前两个数是1,1)
deffib(n):if n <=0:return a, b =1,1print(a, end=" ")if n ==1:returnprint(b, end=" ")for _ inrange(3, n+1): a, b = b, a + b print(b, end=" ") fib(10)# 1 1 2 3 5 8 13 21 34 55
  1. 写函数 count_vowels(s),统计字符串中元音字母个数(a e i o u,不区分大小写)
defcount_vowels(s): s = s.lower()returnsum(1for c in s if c in"aeiou")print(count_vowels("Hello World"))# 3
  1. 有一个字典 d = {“name”:“小明”, “age”:18, “city”:“北京”},写代码把所有 key-value 打印成 “key: value” 格式
d ={"name":"小明","age":18,"city":"北京"}for k, v in d.items():print(f"{k}: {v}")
  1. 写一个函数 remove_duplicates(lst),去掉列表中的重复元素,保持原有顺序
defremove_duplicates(lst): seen =[]for x in lst:if x notin seen: seen.append(x)return seen print(remove_duplicates([1,2,2,3,1,4,5,5]))# [1,2,3,4,5]
  1. 写一个猜数字小游戏(电脑随机1-100,玩家猜,给出太大/太小/恭喜)
import random answer = random.randint(1,100) guess =0 count =0while guess != answer: guess =int(input("猜一个1-100的数字:")) count +=1if guess > answer:print("太大了!")elif guess < answer:print("太小了!")else:print(f"恭喜!猜对了!用了{count}次")
  1. 综合练习:输入一个正整数 n,输出 n 以内所有素数的列表
defget_primes(n): primes =[]for num inrange(2, n+1): is_prime =Truefor i inrange(2,int(num**0.5)+1):if num % i ==0: is_prime =Falsebreakif is_prime: primes.append(num)return primes n =int(input("输入 n:"))print(get_primes(n))

做完这30题,你就基本掌握了 Python 的变量、运算、条件、循环、字符串、列表、函数、简单算法这些最核心的基础。

下一阶段推荐练习方向(按兴趣选):

  • 列表推导式 + 字典 + 集合(再做20题)
  • 文件读写(读写txt、csv)
  • 简单爬虫(requests + beautifulsoup)
  • pygame 小游戏
  • pandas 基础数据处理

你现在做到第几题了?遇到哪道最卡壳?可以贴代码,我帮你 debug~

Read more

Flutter 三方库 double_linked_list 本地化双向链表引擎鸿蒙核心侧适配深探:极尽榨干链表重构算力上限与迭代吞吐性能以支撑复杂游戏数据游标-适配鸿蒙 HarmonyOS ohos

Flutter 三方库 double_linked_list 本地化双向链表引擎鸿蒙核心侧适配深探:极尽榨干链表重构算力上限与迭代吞吐性能以支撑复杂游戏数据游标-适配鸿蒙 HarmonyOS ohos

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 double_linked_list 本地化双向链表引擎鸿蒙核心侧适配深探:极尽榨干链表重构算力上限与迭代吞吐性能以支撑复杂游戏数据游标推演机制 在开发鸿蒙平台的高性能应用(如实时数据流处理、复杂的 UI 撤销/重做逻辑或底层缓存系统)时,如何实现极速的线性数据操作?double_linked_list 库提供了一个纯粹、高效的双向链表实现。本文将详解该库在 OpenHarmony 上的适配要点。 前言 什么是 double_linked_list?不同于标准的 List(基于数组,随机插入代价大),双向链表通过节点间的前后指针关联,使得在已知位置插入或删除节点的时间复杂度维持在 O(1)。在鸿蒙操作系统强调的“极致任务调度”和“大屏高刷交互”背景下,利用该数据结构可以显著优化复杂逻辑下的内存抖动与 CPU 空转。 一、

By Ne0inhk
【算法通关指南:算法基础篇】二分答案专题:1.木材加工 2.砍树

【算法通关指南:算法基础篇】二分答案专题:1.木材加工 2.砍树

🔥小龙报:个人主页 🎬作者简介:C++研发,嵌入式,机器人方向学习者 ❄️个人专栏:《算法通关指南 》 ✨ 永远相信美好的事情即将发生 文章目录 * 前言 * 一、二分答案 * 二、二分答案经典算题 * 2.1 木材加工 * 2.1.1题目 * 2.1.2 算法原理 * 2.1.3 代码 * 2.2 砍树 * 2.2.1 题目 * 2.2.2 算法原理 * 2.2.3 代码 * 总结与每日励志 前言 二分答案是算法竞赛与笔试中极具技巧性的高分解法,核心思路是将复杂求解转化为简洁的二分+判定,

By Ne0inhk
【优选算法】双指针算法:专题二

【优选算法】双指针算法:专题二

目录 【611.有效三角形个数】 1、题目描述 2、实现核心及思路 解题步骤: 思路可视化: 代码实现: 【179.查找总价格为目标值的两个商品】 1、题目描述: 2、实现核心及思路: 代码实现: 【15.三数之和】 1、题目描述: 2、实现核心及思路: 解题步骤: 思路可视化: 代码实现: 【18.四数之和】 1、题目描述: 编辑2、实现核心即思路: 解题步骤: 代码实现: 【611.有效三角形个数】 1、题目描述 2、实现核心及思路 构成三角形的条件:设三角形三边长分别为a(最长边),b(最短边),c。 则有 a + b >

By Ne0inhk

Flutter 三方库 in_date_utils 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、高效的日期逻辑处理与万年历算法引擎

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 in_date_utils 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、高效的日期逻辑处理与万年历算法引擎 在鸿蒙(OpenHarmony)系统的日历、任务管理或考勤应用中,如何快速计算某月的天数、判断闰年、或优雅地对日期进行加减操作?in_date_utils 为开发者提供了一套开箱即用的日期增强工具集。本文将深入实战其在鸿蒙生态中的应用。 前言 什么是 in_date_utils?它是 Dart 原生 DateTime 的强力补丁。在 Flutter for OpenHarmony 的实际开发中,我们经常需要处理诸如“上周一的日期”、“本月最后一个周五”等复杂的业务逻辑。利用该库,我们可以避免重复编写琐碎的日期数学运算,让鸿蒙应用的代码更加简洁、易读且稳健。 一、

By Ne0inhk