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=" ")
相关推荐
逻极20 小时前
OpenClaw「Clawdbot/Moltbot」 深入解析:核心架构深度剖析
python·ai·架构·agent·ai编程·moltbot·openclaw
sayang_shao20 小时前
C++ ONNX Runtime 与 Python Ultralytics 库实现 YOLOv8 模型检测的区别
c++·python·yolo
曹牧20 小时前
Java:强类型转换
开发语言·python
爱学习的阿磊20 小时前
Python入门:从零到一的第一个程序
jvm·数据库·python
naruto_lnq20 小时前
编写一个Python脚本自动下载壁纸
jvm·数据库·python
仟濹20 小时前
【Java加强】1 异常 | 打卡day1
java·开发语言·python
Dingdangcat8621 小时前
基于RetinaNet的建筑表面缺陷检测与识别系统研究_2
python
袖清暮雨21 小时前
Python爬虫(Scrapy框架)
开发语言·爬虫·python·scrapy
modelmd21 小时前
【递归算法】汉诺塔
python·算法
2501_9416527721 小时前
基于YOLO12-A2C2f-FRFN的电缆连接器类型识别与定位
python