编程小白学做题:Python 的经典编程题及详解,附代码和注释(一)
1. 计算斐波那契数列前 n 项
题目:输入整数 n,输出斐波那契数列前 n 项(如 n=5 时,输出 [0, 1, 1, 2, 3])。
思路:
- 前两项固定为 0 和 1,后续每项是前两项之和。
- 用循环依次计算并存储结果。
python
n = int(input("请输入n的值:"))
# 输入n
fib = [0, 1]
# 初始化前两项
if n == 0:
print([])
elif n == 1:
print([0])
else:
for i in range(2, n):
# 从第3项开始计算(索引从2到n-1)
next_num = fib[i-1] + fib[i-2]
# 前两项之和
fib.append(next_num)
print(f"斐波那契前{n}项:{fib[:n]}")
# 截取前n项(避免n=1时越界)
2. 判断回文数
题目:输入一个整数,判断是否为回文数(如 121、1331 是回文数,123 不是)。
思路:
- 将整数转换为字符串,对比正向和反向字符串是否一致。
python
num = input("请输入一个整数:")
# 输入转为字符串(避免负数符号干扰)
if num == num[::-1]:
# 字符串反转后对比
print(f"{num}是回文数")
else:
print(f"{num}不是回文数")
3. 统计字符串中字符频率
题目:输入一段文本,统计每个字符出现的次数(忽略大小写,空格不统计)。
思路:
- 统一转换为小写,过滤空格,用字典记录字符出现次数。
python
text = input("请输入文本:").lower()
# 转小写
char_count = {}
for char in text:
if char == ' ':
# 跳过空格
continue
char_count[char] = char_count.get(char, 0) + 1
# 统计次数
print("字符频率统计:")
for char, count in char_count.items():
print(f"{char}: {count}次")
4. 打印九九乘法表
题目:用循环打印经典的九九乘法表。
思路:
- 嵌套循环:外层控制行数(1~9),内层控制每行的列数(1~ 当前行数)。
python
for i in range(1, 10):
# 外层循环:行数i(1~9)
for j in range(1, i+1):
# 内层循环:列数j(1~i)
print(f"{j}×{i}={i*j}", end="\t")
# 制表符对齐
print()
# 换行
5. 找出列表中的重复元素
题目:给定一个列表,找出其中重复出现的元素(如 [1, 2, 2, 3, 3, 3],输出 [2, 3])。
思路:
- 用集合记录已出现的元素,遍历列表时对比,收集重复元素。
python
nums = [1, 2, 2, 3, 3, 3, 4, 4]
seen = set()
# 存储已出现的元素
duplicates = []
# 存储重复元素
for num in nums:
if num in seen:
# 若已存在于seen中,说明是重复元素
duplicates.append(num)
else:
seen.add(num)
# 否则添加到seen中
# 去重并排序(可选)
duplicates = list(set(duplicates))
# 去重
duplicates.sort()
# 排序
print("重复元素:", duplicates)
学习建议:
- 先理解逻辑:尝试自己画流程图或手动计算步骤,再写代码。
- 调试代码:用print()输出中间变量,观察程序运行过程。
- 扩展练习:斐波那契题:尝试用递归实现(注意递归深度限制)。回文数题:尝试不转换为字符串,用数学方法判断(如反转整数)。
通过这些题目可练习循环、条件判断、数据结构(列表、字典、集合)等核心知识点,适合小白巩固基础!