程序员文章、书籍推荐和程序员创业信息与资源分享平台

网站首页 > 技术文章 正文

编程小白学做题:Python 的经典编程题及详解,附代码和注释(一)

hfteth 2025-07-06 12:19:03 技术文章 4 ℃

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)

学习建议:

  1. 先理解逻辑:尝试自己画流程图或手动计算步骤,再写代码。
  2. 调试代码:用print()输出中间变量,观察程序运行过程。
  3. 扩展练习:斐波那契题:尝试用递归实现(注意递归深度限制)。回文数题:尝试不转换为字符串,用数学方法判断(如反转整数)。

通过这些题目可练习循环、条件判断、数据结构(列表、字典、集合)等核心知识点,适合小白巩固基础!

最近发表
标签列表