Python 编程实战:从基础语法到算法实现 (1)

在 Python 学习的过程中,通过解决实际的编程问题能够快速提升我们的代码能力和逻辑思维。本文将围绕几个经典的编程练习题展开,涵盖日期处理、素数判断、完数求解、数字操作以及排列组合等多个知识点,带你一起感受 Python 编程的魅力。

一、获取并格式化当前系统时间

在 Python 中,datetime模块为我们提供了丰富的日期和时间处理功能。我们可以轻松获取当前系统时间,并按照指定格式进行格式化输出。

python 复制代码
import datetime
# 获取当前系统时间
now = datetime.datetime.now()
print("当前系统时间:", now)
# 格式化为"年-月-日 小时:分钟:秒"
now_str = now.strftime("%Y-%m-%d %H:%M:%S")
print("格式化后的时间:", now_str)

二、寻找 2~1000 内的回文素数

素数(质数)是指大于 1 且只能被 1 和它本身整除的整数,回文素数则是指既是素数又是回文数的数。要解决这个问题,我们需要分别实现素数判断和回文数判断的功能。

python 复制代码
def is_palindrome(num):
    """判断一个数是否为回文数"""
    num_str = str(num)
    return num_str == num_str[::-1]

def is_prime(num):
    """判断一个数是否为素数"""
    if num <= 1:
        return False
    if num == 2:
        return True
    if num % 2 == 0:
        return False
    for i in range(3, int(num**0.5) + 1, 2):
        if num % i == 0:
            return False
    return True

# 寻找2~1000内的回文素数
palindrome_primes = []
for num in range(2, 1001):
    if is_prime(num) and is_palindrome(num):
        palindrome_primes.append(num)
print("2~1000内的所有回文素数:", palindrome_primes)
python 复制代码
import math

def is_perfect_number(num):
    """判断一个数是否为完数"""
    if num <= 1:
        return False
    sum_factors = 1  # 1是所有大于1的数的真因子
    for i in range(2, int(math.sqrt(num)) + 1):
        if num % i == 0:
            sum_factors += i
            if num // i != i:  # 避免重复添加平方数的情况
                sum_factors += num // i
    return sum_factors == num

print("1000以内的所有完数:")
for num in range(2, 1001):
    if is_perfect_number(num):
        print(num, end=" ")

三、求解 1000 以内的完数

完数是指一个数恰好等于它的所有真因子(除了自身以外的约数)之和。例如 6 的真因子是 1、2、3,而 1+2+3=6,所以 6 是完数。

python 复制代码
import math

def is_perfect_number(num):
    """判断一个数是否为完数"""
    if num <= 1:
        return False
    sum_factors = 1  # 1是所有大于1的数的真因子
    for i in range(2, int(math.sqrt(num)) + 1):
        if num % i == 0:
            sum_factors += i
            if num // i != i:  # 避免重复添加平方数的情况
                sum_factors += num // i
    return sum_factors == num

print("1000以内的所有完数:")
for num in range(2, 1001):
    if is_perfect_number(num):
        print(num, end=" ")
相关推荐
love530love19 小时前
LiveTalking 数字人项目 Windows 部署完全指南(EPGF 架构)
人工智能·windows·python·架构·livetalking·epgf
遇事不決洛必達19 小时前
【Python基础】GIL 锁是什么及其对爬虫的影响
爬虫·python·线程·进程·gil锁
CryptoPP20 小时前
快速对接东京证券交易所API数据:实战指南与代码示例
开发语言·人工智能·windows·python·信息可视化·区块链
探物 AI21 小时前
把 MambaOut 塞进 YOLOv11:会有什么样的反应
python·yolo·计算机视觉
如竟没有火炬21 小时前
最大矩阵——单调栈
数据结构·python·线性代数·算法·leetcode·矩阵
阳区欠21 小时前
【LangChain】LLM基础介绍
开发语言·python·langchain
Cosolar21 小时前
保姆级 CrewAI 教程:从零构建多智能体协作系统
人工智能·python·架构
GDAL1 天前
使用 uv 管理 Python 版本
python·uv·版本
真实的菜1 天前
Redis 从入门到精通(十二):典型业务场景实战 —— 排行榜、限流器、秒杀系统、Session 共享
数据库·redis·python
cup111 天前
[开源] Meta Assistant / 告别命令行,我为一堆 Python 脚本做了一个 Windows 任务栏的“家”
windows·python·工具·nuitka·脚本运行