Python小程序集锦
- 程序1:数字组合
- 程序2:猜数字
- 程序3:猜时间
- 程序4:判断整数大小
- 程序5:斐波那契数列
- 程序6:水仙花数
- 程序7:数字求和
- 程序8:平方根
- 程序9:if语句
- 程序10:阿姆斯特朗数
- 程序11:输出指定范围的素数(else语句)
- 程序12:生成日历
- 程序13:统计字符串中的字符
- 程序14:文件的读取
- 程序15:十进制转二进制、八进制、十六进制
- 程序16: 生成10个两位的随机素食
- 程序17: 计算三角形面积
- 程序18:字符串大小写转换
- 程序19: 获取昨天日期
- 程序20: 变量交换
- 程序21: 质数判断
- 程序22: 简单计算器
- 程序23: 最大公约数
- 程序24: 最小公倍数
- 程序25: 字符串判断
- 程序26: 合并文件数据
- 程序27: 猜数游戏
- 程序28:为数据加密
- 程序29:平方运算
- 程序30: 计算0-7组成的奇数个数
- 程序31:求值
- 程序32:猴子分桃
- 程序33:淘汰游戏
- 程序34:分解质因子
- 程序35:取整数右端的4~7位
- 程序36:判断4位回文数
- 程序37:汉诺塔(递归函数)
- 程序38:判断闰年
- 程序39:寻找自幂数(水仙花数)
- 程序40:多维数据
- 程序41: 验证哥德巴赫猜想
- 程序42: 解方程
- 程序43: 异常处理
- 程序44: 统计不及格人数(continue语句)
- 程序45: 求直角三角形的斜边
- 程序46: 问年龄
- 程序47:求相同数字的和
- 程序48:找出1000以内的所有完数
- 序49:公民类
- 程序50:复数类
- 程序51:单词计数器
- 程序52:文字冒险游戏
- 程序53:密码生成器
- 程序54:文字迷宫游戏
- 程序55:天气查询程序
- 程序56:一个简单的数据库应用
- 程序57:字符串排序
- 程序58:猴子分桃子
- 程序59:猜数字
- 程序60:读文件
- 程序61:类型转换
- 程序62:进制转换-八进制转十进制
- 程序63:求数
- 程序64:字符串连接
- 程序65:两个字符串连接
- 程序66:数学分析-求9的位数
- 程序67:结构体的初步学习-结构体变量传递
- 程序68:打印
- 程序69:数据加密
- 程序70:列表学习
- 程序80:时间函数学习-1
- 程序81:时间函数学习-2
- 程序82:时间函数学习-3
程序1:数字组合
问题描述:
有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
问题分析:
可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去掉不满足条件的排列。
for i in range(1,5):
for j in range(1,5):
for k in range(1,5):
if i!=j and j!=k and i!=k:
print(i,j,k)
程序2:猜数字
问题描述:
一个整数,它加上100和加上268后都是一个完全平方数,请问该数是多少?
问题分析:
在10000以内判断,将该数i加上100后再开方,加上268后再开方,如果开方后的结果满足如下条件,即是结果。
xx =(i+100)
yy=(i+268)
import math
for i in range(1,10000):
x=int(math.sqrt(i+100))
y=int(math.sqrt(i+268))
if (x*x==i+100)and(y*y==i+268):
print(i)
程序3:猜时间
问题描述:
输入某年某月某日,判断这一天是这一年的第几天?
问题分析:
以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊情况,闰年且输入月份大于2时需考虑多加一天。
year=int(input("请输入年份"))
month=int(input("请输入月份"))
day=int(input("请输入日期"))
months=(0,31,59,90,120,151,181,212,243,273,304,334)
if 0<month<=12:
sum=months[month-1]
else:
print('输入的月份有误')
sum+=day
leap=0
if (year%400==0) or ((year%4==0) and (year%100!=0)):
leap=1
if(leap==1)and(month>2):
sum+=1
print("今天是第%d天"%sum)
程序4:判断整数大小
问题描述:
输入三个整数x,y,z,请把这三个数由小到大输出。
问题分析:
可以借助列表的sort方法完成排序。首先将用户输入的整数存放在列表中,列表从小到大排序后,通过遍历的方式输出列表中的值即可。
x=int(input("请输入进行比较的第1个数:"))
y=int(input("请输入进行比较的第2个数:"))
z=int(input("请输入进行比较的第3个数:"))
list=[x,y,z]
list.sort()
for i in range(len(list)):
print(list[i])
程序5:斐波那契数列
程序分析
斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、……。
在数学上,费波那契数列是以递归的方法来定义:
F0 = 0 (n=0)
F1 = 1 (n=1)
Fn = F[n-1]+ Fn-2
def fib(n):
if n==1 or n==2:
return 1
return fib(n-1)+fib(n-2)
print(fib(10))
程序6:水仙花数
程序分析
所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。
for i in range(100,1000):
a=int(i/100)
b=int(i/10)%10
c=i%10
if i==a**3+b**3+c**3:
print(i)
程序7:数字求和
程序分析
根据程序描述,该程序实现过程大概分为如下几步:
- 提示用户输入第1个数字
- 提示用户输入第2个数字
- 对两个数字进行相加
- 输出两个数字相加的和
num1=input("请输入第1个数字:")
num2=input("请输入第2个数字:")
sum=float(num1)+float(num2)
print("数字%s和%s相加之和是%.1f"%(num1,num2,sum))
程序8:平方根
程序分析
关于计算平方根的,可以使用在指数运算符 ** 来计算改数的平方根,也可以使用math函数中的sqrt,不同的是,指数**只适用于正数,而sqrt适用于任何数。接下来,按照下列步骤实现程序:
- 提示用户输入一个数(必须将输入的数转为数字类型)
- 使用math函数的sqrt计算这个数的平方根
- 输出运算结果
import math
num=int(input("请输入要计算平方根的数字:"))
result=math.sqrt(num)
print("数字%d的平方根是%f"%(num,result))
程序9:if语句
程序分析
正数、负数或零的判断非常简单,只需要判断这个数是否大于零,小于零或者等于零。由于判断的条件大于2个,这里我们使用if…elif…else判断。
num = float(input("输入一个数字: "))
if num > 0:
print("正数")
elif num == 0:
print("零")
else:
print("负数")
程序10:阿姆斯特朗数
程序分析
如果一个n位正整数等于其各位数字的n次方之和,则称该数为阿姆斯特朗数。 例如1^3 + 5^3 + 3^3 = 153。
1000以内的阿姆斯特朗数: 1, 2, 3, 4, 5, 6, 7, 8, 9, 153, 370, 371, 407。
# 获取用户输入的数字
num = int(input("请输入一个数字: "))
# 初始化变量 sum
sum = 0
# 指数
n = len(str(num))
# 检测
temp = num
while temp > 0:
digit = temp % 10
sum += digit ** n
temp //= 10
# 输出结果
if num == sum:
print(num,"是阿姆斯特朗数")
else:
print(num,"不是阿姆斯特朗数")
程序11:输出指定范围的素数(else语句)
程序分析
由程序描述可知,要想输出指定范围的素数,可以按照下列步骤开发:
- 提示用户输入指定的范围,分别是范围的最小值和最大值
- 使用for循环在指定范围内进行循环
- 由于满足素数的条件是只能被1和本身整除,所以可以使用if语句判断是否能整除,如果能,则输出素数。
lower = int(input("输入区间最小值: "))
upper = int(input("输入区间最大值: "))
for num in range(lower,upper + 1):
# 素数大于 1
if num > 1:
for i in range(2,num):
if (num % i) == 0:
break
else:
print(num)
程序12:生成日历
程序分析
Calendar模块有很广泛的方法用来处理年历和月历,例如打印某月的月历。
# 引入日历模块
import calendar
# 输入指定年月
yy = int(input("输入年份: "))
mm = int(input("输入月份: "))
# 显示日历
print(calendar.month(yy,mm))
程序13:统计字符串中的字符
程序分析
开发步骤如下:
- 提示用户输入字符串
- 声明四个变量,分别用于统计英文字母、空格、数字和其他字符的个数
- 使用for循环遍历字符串中的字符,使用if判断语句判断遍历的字符满足哪个条件,如果满足条件,则对应的变量加1
str=input("请输入一个字符串:")
letters = 0
space = 0
digit = 0
others = 0
for c in str:
if c.isalpha():
letters += 1
elif c.isspace():
space += 1
elif c.isdigit():
digit += 1
else:
others += 1
print("字符串共有%d个英文字母,%d个空格,%d个数字,%d个其他字符
"%(letters,space,digit,others))
程序14:文件的读取
程序分析
开发步骤如下:
- 提示用户输入一个字符串
- 使用字符串的upper方法将字符串的小写字母全部转换为大写字母
- 使用write方法将字符串写入文件,需要注意的是,在写文件之前,首先要打开文件,完成写数据的操作后,要切记关闭文件。
fp = open('test.txt','w')
string = input('please input a string:\n')
string = string.upper()
fp.write(string)
fp = open('test.txt','r')
print(fp.read())
fp.close()//一定要关闭文件资源,以防资源浪费
程序15:十进制转二进制、八进制、十六进制
程序分析
不同进制之间的转换,需要用到下列方法:
1、 bin():将十进制的数转为二进制
2、 oct():将十进制的数转为八进制
3、 hex(): 将十进制的数转为十六进制
# 获取用户输入十进制数
dec = int(input("输入数字:"))
print("十进制数为:", dec)
print("转换为二进制为:", bin(dec))
print("转换为八进制为:", oct(dec))
print("转换为十六进制为:", hex(dec))
程序16: 生成10个两位的随机素食
程序分析
Python的random模块提供了随机数生成方法random.randint(a,b),它返回一个大于等于a,小于等于b的随机整数。
import random
n=0
while n<10:
x=random.randint(10,99) #获得一个两位的随机整数
#判断x是否为素数
a=2
while a<x-1:
if x%a==0: #若余数为0,说明x不是素数,结束当前循环
break
a+=1
else:
print(x) #若正常结束循环时,说明x是素数,输出
n+=1 #累计素数个数
程序17: 计算三角形面积
程序分析
要想计算三角形的面积,需要获取三角形的三边长度,假设三角形的三边分别是a,b,c,那么面积的计算方式如下:
三角形半周长s=(a+b+c)/2
三角形面积=(s*(s-a)(s-b)(s-c)) ** 0.5
a = float(input('输入三角形第一边长: '))
b = float(input('输入三角形第二边长: '))
c = float(input('输入三角形第三边长: '))
# 计算半周长
s = (a + b + c) / 2
# 计算面积
area = (s*(s-a)*(s-b)*(s-c)) ** 0.5
print('三角形面积为 %0.2f' %area)
程序18:字符串大小写转换
程序分析
字符串str提供了很多转换字母的方法,具体如下:
- upper():将所有字符中的小写字母转换为大写字母
- lower():把所有字符中的大写字母转为小写字母
- capitalize():把第一个字母转化为大写字母,其余小写
- title():把每个单词的第一个字母转化为大写,其余小写
str = "www.runoob.com"
print(str.upper()) # 把所有字符中的小写字母转换成大写字母
print(str.lower()) # 把所有字符中的大写字母转换成小写字母
print(str.capitalize()) # 把第一个字母转化为大写字母,其余小写
print(str.title()) # 把每个单词的第一个字母转化为大写,其余小写
程序19: 获取昨天日期
程序分析
# 引入 datetime 模块
import datetime
def getYesterday():
today=datetime.date.today()
oneday=datetime.timedelta(days=1)
yesterday=today-oneday
return yesterday
# 输出
print(getYesterday())
程序20: 变量交换
程序分析
与其他语言不同,Python中的变量可以通过下列方式进行赋值:
x,y = y,x
上述代码的作用就是将x的值赋给y,将y的值赋给x,即x和y值的互换。
# 用户输入
x = input('输入 x 值: ')
y = input('输入 y 值: ')
# 不使用临时变量
x,y = y,x
print('交换后 x 的值为: {}'.format(x))
print('交换后 y 的值为: {}'.format(y))
程序21: 质数判断
程序描述
一个大于1的自然数,除了1和它本身外,不能被其他自然数(质数)整除(2, 3, 5, 7等),换句话说就是该数除了1和它本身以外不再有其他的因数。
# 用户输入数字
num = int(input("请输入一个数字: "))
# 质数大于 1
if num > 1:
# 查看因子
for i in range(2, num):
if (num % i) == 0:
print(num, "不是质数")
print(i, "乘于", num // i, "是", num)
break
else:
print(num, "是质数")
# 如果输入的数字小于或等于 1,不是质数
else:
print(num, "不是质数")
程序22: 简单计算器
程序分析
简单计算器的开发流程如下:
- 打印菜单,提示用户选择要进行的运算
- 用户选择运算类型
- 接收用户输入的值,用于参与运算
- 输出运算的结果
需要注意的是,由于接受的用户输入是字符串,需要将字符串转为数值类型
# 定义函数
def add(x, y):
"""相加"""
return x + y
def subtract(x, y):
"""相减"""
return x - y
def multiply(x, y):
"""相乘"""
return x * y
def divide(x, y):
"""相除"""
return x / y
# 用户输入
print("选择运算:")
print("1、相加")
print("2、相减")
print("3、相乘")
print("4、相除")
choice = input("输入你的选择(1/2/3/4):")
num1 = int(input("输入第一个数字: "))
num2 = int(input("输入第二个数字: "))
if choice == '1':
print(num1,"+",num2,"=", add(num1,num2))
elif choice == '2':
print(num1,"-",num2,"=", subtract(num1,num2))
elif choice == '3':
print(num1,"*",num2,"=", multiply(num1,num2))
elif choice == '4':
print(num1,"/",num2,"=", divide(num1,num2))
else:
print("非法输入")
程序23: 最大公约数
程序描述
编写一个程序,计算两个数的最大公约数。
# 定义一个函数
def hcf(x, y):
"""该函数返回两个数的最大公约数"""
# 获取最小值
if x > y:
smaller = y
else:
smaller = x
for i in range(1,smaller + 1):
if((x % i == 0) and (y % i == 0)):
hcf = i
return hcf
# 用户输入两个数字
num1 = int(input("输入第一个数字: "))
num2 = int(input("输入第二个数字: "))
print( num1,"和", num2,"的最大公约数为", hcf(num1, num2))
程序24: 最小公倍数
程序描述
编写一个程序,计算两个数的最小公倍数。
# 定义函数
def lcm(x, y):
# 获取最大的数
if x > y:
greater = x
else:
greater = y
while(True):
if((greater % x == 0) and (greater % y == 0)):
lcm = greater
break
greater += 1
return lcm
# 获取用户输入
num1 = int(input("输入第一个数字: "))
num2 = int(input("输入第二个数字: "))
print( num1,"和", num2,"的最小公倍数为", lcm(num1, num2))
程序25: 字符串判断
程序描述
编写一个程序,演示Python字符串中和判断有关的方法的使用。
程序分析
字符串中常见的判断操作的方法如下所示:
1、 isalnum(): 判断所有字符都是数字或者字母
2、 isalpha(): 判断所有字符都是字母
3、 isdigit():判断所有字符都是数字
4、 islower():判断所有字符都是小写
5、 isupper():判断所有字符都是大写
6、 istitle():判断所有单词都是首字母大写,像标题
7、 isspace():判断所有字符都是空白字符、\t、\n、\r
print("测试实例一")
str = "www.itheima.com"
print(str.isalnum()) # 判断所有字符都是数字或者字母
print(str.isalpha()) # 判断所有字符都是字母
print(str.isdigit()) # 判断所有字符都是数字
print(str.islower()) # 判断所有字符都是小写
print(str.isupper()) # 判断所有字符都是大写
print(str.istitle()) # 判断所有单词都是首字母大写,像标题
print(str.isspace()) # 判断所有字符都是空白字符、\t、\n、\r
print("------------------------")
# 测试实例二
print("测试实例二")
str = "itheima"
print(str.isalnum())
print(str.isalpha())
print(str.isdigit())
print(str.islower())
print(str.isupper())
print(str.istitle())
print(str.isspace())
程序26: 合并文件数据
程序描述
有两个磁盘文件A和B,各存放一行字母,要求把这两个文件中的信息合并(按字母顺序排列), 输出到一个新文件C中。
fp = open('test1.txt')
a = fp.read()
fp.close()
fp = open('test2.txt')
b = fp.read()
fp.close()
fp = open('test3.txt', 'w')
l = list(a + b)
l.sort()
s = ''
s = s.join(l)
fp.write(s)
fp.close()
程序27: 猜数游戏
程序描述
编写一个猜数游戏,该游戏会随机产生一个数字,用户可以随意输入一个数进行比较,在比较过程中,会不断提示用户输入的数是大了还是小了,直到用户输入的数等于随机数,程序终止。
import time
import random
play_it = input('do you want to play it.(\'y\' or \'n\')')
while play_it == 'y':
c = input('input a character:\n')
i = random.randint(0, 2 ** 32) % 100
print('please input number you guess:\n')
start = time.clock()
a = time.time()
guess = int(input('input your guess:\n'))
while guess != i:
if guess > i:
print('please input a little smaller')
guess = int(input('input your guess:\n'))
else:
print('please input a little bigger')
guess = int(input('input your guess:\n'))
end = time.clock()
b = time.time()
var = (end - start) / 18.2
print(var)
if var < 15:
print('you are very clever!')
elif var < 25:
print('you are normal!')
else:
print('you are stupid!')
print('Congradulations')
print('The number you guess is %d' % i)
play_it = input('do you want to play it.')
程序28:为数据加密
程序描述
某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。
from sys import stdout
a = int(input('input a number:\n'))
aa = []
aa.append(a % 10)
aa.append(a % 100 / 10)
aa.append(a % 1000 / 100)
aa.append(a / 1000)
for i in range(4):
aa[i] += 5
aa[i] %= 10
for i in range(2):
aa[i],aa[3 - i] = aa[3 - i],aa[i]
for i in range(3,-1,-1):
stdout.write(str(aa[i]))
程序29:平方运算
程序描述
编写程序,求输入数字的平方,如果平方运算后小于 50 则退出。
TRUE = 1
FALSE = 0
def SQ(x):
return x * x
print('如果输入的数字小于 50,程序将停止运行。')
again = 1
while again:
num = int(input('Please input number'))
print('运算结果为 %d' % (SQ(num)))
num=SQ(num)
if num >= 50:
again = TRUE
else:
again = FALSE
程序30: 计算0-7组成的奇数个数
程序描述
编写一个程序,计算0—7所能组成的奇数个数。
sum = 4
s = 4
for j in range(2,9):
print(sum)
if j <= 2:
s *= 7
else:
s *= 8
sum += s
print('sum = %d' % sum)
程序31:求值
程序描述
809*??=800*??+9*??+1 其中??代表的两位数,8*??的结果为两位数,9*??的结果为3位数。求??代表的两位数,及809*??后的结果。
a = 809
for i in range(10,100):
b = i * a + 1
if b >= 1000 and b <= 10000 and 8 * i < 100 and 9 * i >= 100:
print(b,'/',i,' = 809 * ',i,' + ', b % i)
程序32:猴子分桃
程序描述
海滩上有一堆桃子,五只猴子来分。第一只猴子把这堆桃子平均分为五份,多了一个,这只猴子把多的一个扔入海中,拿走了一份。第二只猴子把剩下的桃子又平均分成五份,又多了一个,它同样把多的一个扔入海中,拿走了一份,第三、第四、第五只猴子都是这样做的,问海滩上原来最少有多少个桃子?
i = 0
j = 1
x = 0
while (i < 5):
x = 4 * j
for i in range(0, 5):
if (x % 4 != 0):
break
else:
i += 1
x = (x / 4) * 5 + 1
j += 1
print(x)
程序33:淘汰游戏
程序描述
有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。
nmax = 50
n = int(input('请输入总人数:'))
num = []
for i in range(n):
num.append(i + 1)
i = 0
k = 0
m = 0
while m < n - 1:
if num[i] != 0 : k += 1
if k == 3:
num[i] = 0
k = 0
m += 1
i += 1
if i == n : i = 0
i = 0
while num[i] == 0: i += 1
print(num[i])
程序34:分解质因子
程序描述
编写一个程序,用于对一个数进行分解质因子。
n=int(input('please input n:'))
result=[]
i=2
str1=str(n)+'='
while n>1:
if n%i==0:
n/=i
result.append(str(i))
i -= 1
i +=1
str1+='*'.join(result)
print(str1)
程序35:取整数右端的4~7位
程序描述
编写程序,取一个整数a从右端开始的4〜7位。
可以这样考虑:
(1)先使a右移4位。
(2)设置一个低4位全为1,其余全为0的数。可用(0<<4)
(3)将上面二者进行&运算。
a = int(input('input a number:\n'))
b = a >> 4
c = ~(~0 << 4)
d = b & c
print('%o\t%o' % (a, d))
程序36:判断4位回文数
程序描述
用户输入一个4位的整数,如果是回文数显示True,如果不是回文数显示False。
程序分析
回文数,就是反过来的数字和正着的数字是相同的,如1221,倒过来的数还是1221,这就是一个回文数,1234倒过来是4321,不相等,就不是回文数。
一个四位数abcd可以写为I1=a1000+b100+c10+d
那么倒过来的数就可以写成I2=d1000+c100+b10+a
如果I1和I2相等,那么这就是一个回文数。I1==I2的结果就是True,否则就是False。
一个四位数I1,分离各位数字的方法是:
千位:I1/1000
百位:I1/100%10
十位:I1/10%10
个位:I1%10
因此,判断回文数,如果使用a、b、c、d表示整数I1的千位、百位、十位、个位,开发步骤如下:
1.用户输入一个数字l1
2.分离出千位、百位、十位、个位
3.组合出新的数字I2=d1000+c100+b*10+a
4.判断l1是否等于l2 (= =)
5.输出结果
I1=int(input("请输入一个四位数:"))
a=int(I1/1000)
b=int(I1/100%10)
c=int(I1/10%10)
d=int(I1%10)
I2=d*1000+c*100+b*10+a
if I1==I2:
print("True")
else:
print("False")
程序37:汉诺塔(递归函数)
程序描述
古代有一个梵塔,塔内有A、B、C三个基座,A座上有64个盘子,盘子大小不等,大的在下,小的在上。有人想把这64个盘子从A座移到C座,但每次只允许移动一个盘子,并且在移动的过程中,3个基座上的盘子始终保持大盘在下,小盘在上。在移动过程中盘子可以放在任何一个基座上,不允许放在别处。编写程序,用户输入盘子的个数,显示移动的过程。
程序分析
假定盘子从大到小依次编号为:盘1、盘2、…
(1) 如果只有一个盘子,则不需要利用B座,直接将盘子从A移动到C
(2) 如果有2个盘子,可以先将盘2移动到B,将盘1移动到C后,再将盘2移动到C
(3) 如果有3 个盘子,那么根据2个盘子的结论,可以借助C将盘2和盘3从A移动到B,将盘1从A移动到C,A变成空座;借助A座,将B上的两个盘子移动到C
上述思路可以一直扩展下去,根据以上的分析,可以写出下面的递归表达:
将一个盘子从A移动到C:
借助C将n-1个盘子从A移动到B
将一个盘子从A移动到C n>1
借助A将n-1个盘子从B移动到C
借助B将n个盘子从A移动到C
为了编写一个递归函数实现“借助B将n个盘子从A移到C”,比较等式左右两边相似操作,会发现:
(1) 盘子的数量从n变化到n-1,问题规模缩小了,显然n是一个可变的参数
(2) 盘子的起始位置是变化的,等式左侧是A,右侧是A或B
(3) 盘子的最终位置是变化的,等式左侧是C、右侧是B或C
(4) 同样被借助的位置也是变化的
因此,递归函数共有盘子数、起始位置、借助位置和最终位置4个变量,因此函数有4个可变参数。假定函数的参数一次为盘子数、初始位置、借助位置和最终位置,则可写出下面函数。
def Hanoi(n,ch1,ch2,ch3):
if n==1:
print(ch1,'->',ch3)
else:
Hanoi(n-1,ch1,ch3,ch2)
print(ch1,'->',ch3)
Hanoi(n-1,ch2,ch1,ch3)
N=int(input("请输入盘子的数量:"))
Hanoi(N,'A','B','C')
程序38:判断闰年
程序描述
用户输入一个年份,如果是闰年输出True,如果不是,输出False。
程序分析
判断闰年的规则如下:
(1) 能被4整除且不能被100整除的为闰年
(2) 能被400整除的是闰年
在上述两个规则中,只要有一条规则成立,则年份为闰年。
year = int(input("请输入年份:"))
if year%100 != 0 and year%4 == 0 or year%400 == 0:
print("%d为闰年"%year)
else:
print("%d不是闰年"%year)
程序39:寻找自幂数(水仙花数)
程序描述
用户输入位数n,找出并显示出所有n位的自幂数。
程序分析
自幂数是指一个n位正整数,如果它的各位数字的n次方的和加起来等于这个数,数学家称这样的数为自幂数。例如,13+53+33=153,153就是一个3位的自幂数,3位自幂数也称为水仙花数。本程序设n的数值为1~6,当n大于6时,程序退出。
#自幂数
start=0
end=0
digit=0
m=0
n=int(input('请选择自幂数的位数【1,2,3,4,5,6】:'))
while 0<n<7:
start=pow(10,n-1)
end=pow(10,n)-1
print(n,'位数的自幂数有:')
for k in range(start,end+1):
m=k
total=0
while m!=0:
digit=m%10
total+=pow(digit,n)
m=m//10
if total==k:
print(str(k),end=' ')
n=int(input('\n 请选择自幂数的位数【1,2,3,4,5,6】:'))
else:
print('输入位数不在范围内,程序结束。')
程序40:多维数据
程序描述
在现实生活中,经常需要处理多维数据,比如,二维矩阵,三维矩阵等。在Python中可以用嵌套列表来表示多维数据,比如,下面的一个列表表示的是33的二维数据。
M=[[1,2,3],[‘a’,’b’,’c’],[7,8,9]]
显然这种嵌套列表与通常意义的矩阵有所不同,主要不同表现在以下两个方面。
(1) 列表的每个维度长度可以不同
(2) 列表的元素数据类型可以不同
尽管如此,使用嵌套列表表示多维矩阵依然是Python语句中的常见用法,比如列表N=[[1,2,3],[4,5,6],[7,8,9]]表示下面矩阵。
123
456
789
而对于第(i,j)位置的访问使用N[i][j]即可。
如果要通过键盘输入数据来初始化一个22的矩阵,可以使用下面的语句。
a=[]
for i in range(2):
a.append([])
for j in range(2):
v=int(input("请输入元素:"))
a[i].append(v)
print(a)
程序41: 验证哥德巴赫猜想
程序描述
哥德巴赫猜想说是说,任何一个超过2的偶数都可以写成两个素数之和,例如,4=2+2,8=5+3等。本例要求根据用户输入的偶数找出其素数和的分解形式
程序分析
一个简单的方法的,对于输入的偶数N,找出其所有分解,逐一验证每一个满足N=k1+k2的分解中k1和k2是否都是素数。比如对于数字12,验证分解(2,10),(3,9)、(4,8)、(5、7)、(6,6)中有没有两个数都是素数的情形。如果有,哥德巴赫猜想该数就是成立的。这种算法对于只验证一个数字N的所有分解的情形是合适的。但对于需要验证多个偶数N的情形效率欠佳。比如需要验证10、12、16三个数,它们有分解5+5、5+7、5+11,这样验证这几个分解时就要判断5是不是素数,重复的运算会很多。
本案例采用另一种思路,首先建立一个素数表,该素数表要足够长,可以覆盖偶数N所有分解中可能遇到的素数。而后考察N的每个分解,看看分解出来的两个数是否都包含在素数表中,若是,则找到一种素数分解。
def main():
# 输入待验证的偶数
N=int(input("请输入待验证的偶数:"))
while N<3 or N%2==1:
print("输入的数不符合要求")
N=int(input("请输入待验证的偶数n(n>2):"))
#生成素数表
Prime=set()
for i in range(2,N+1):
Prime.add(i)
for i in range(2,N+1):
if i in Prime:
for k in range(2*i,N+1,i):
if k in Prime:
Prime.remove(k)
#验证该偶数能否分解为两个素数之和
for e in Prime:
f=N-e
if f>=e and f in Prime:
print(N,'=',e,'+',f)
main()
程序42: 解方程
程序描述
编写程序,解一元二次方程 ax2+bx+c=0。
from math import *
print("本程序求 ax^2+bx+c=0 的根")
a=float( input("请输入 a:") )
b=float( input("请输入 b:") )
c=float( input("请输入 c:") )
delta=b*b-4*a*c
if(delta>=0):
delta=sqrt(delta)
x1=(-b+delta)/2/a
x2=(-b-delta)/(2*a)
print("两个实根分别为:",x1,x2)
else:
print("没有实根")
程序43: 异常处理
程序描述
输入两个整数,打印它们相除之后的结果。对输入的不是整数或除数为零,进行异常处理。
程序分析
在对两个整数相除过程中,如果遇到输入的不是整数或者除数为零,那么程序会终止,不再执行其他语句,这就是出现了异常。系统自动的处理就是停止执行,给出提示,为了执行这种情况,不让程序结束,可以将会出现异常的代码写在try中,让except按照异常类名处理异常。
k=0
while(k<3):
try:
x=int(input('请输入第一个整数:'))
y=int(input('请输入第二个整数:'))
print('x/y=',x/y)
except ValueError:
print('请输入一个整数。')
except ZeroDivisionError:
print('除数不能为零。')
k=k+1
程序44: 统计不及格人数(continue语句)
程序描述
有若干成绩,统计及格人的平均成绩。
x=[98,72,80,45,30,89,92,54,48,82,67,76]
sum=0
k=0;
for item in x:
if(item<60):
continue
sum=sum+item
k=k+1;
if(k!=0):
print("及格人数",k,"人,平均成绩是",sum/k)
程序45: 求直角三角形的斜边
程序描述
输入直角三角形的两个直角边长度a、b,求斜边c的长度。
数学公式 c=√(a2+b2)
在Python中,乘法使用“”号表示,如aa就是a的平方。
除此之外,还有开方根的运算,可以通过Python中math模块内置的函数来实现,为此,我们可以在程序中使用import导入math模块,然后调用开方的函数sqrt实现。
# 勾股定理求斜边长度
###################################
from math import *
a=float(input("请输入斜边 1 的长度")) #输入实数
b=float(input("请输入斜边 2 的长度")) #输入实数
c=a*a+b*b #计算,得到的是斜边的平方
c=sqrt(c) #开方,得到的是斜边长
print("斜边长为:",c) #显示,一项是字符串,一项是 c 表示的斜边长
程序46: 问年龄
程序描述
有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问第五个人多大?
###################################
#题目非常符合递归函数的过程,所以本题采用递归函数完成。
#函数把问到的第几个人作为参数i,当i的值为1时,函数返回10,其它情况均为第i-1人年龄的基础上加2.
###################################
def fun(i):
if i==1:
return 10
return fun(i-1)+2
print(fun(5))
程序47:求相同数字的和
程序描述
求s=a+aa+aaa+aaaa+aa…a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加由键盘控制。
#根据用户输入的个数(长度)决定循环的次数。
#区分每次循环输出的内容,只要是最后一次循环,就直接输出最终的结果,其余皆为本次结果跟上加号。
#先从个位的数字开始计算,每执行一次循环就把上次的结果数乘以10,使得每次的结果为30、330、3330,然后再加上个位的基本数字就行。
def test():
basis = int(input("输入一个基本的数字:"))
n = int(input("输入数字的长度:"))
b = basis
sum = 0
for i in range(0, n):
if i == n - 1:
print("%d " % (basis))
else:
print("%d +" % (basis))
sum += basis
basis = basis * 10 + b
print('= %d' % (sum))
test()
程序48:找出1000以内的所有完数
程序描述
一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3.编程找出1000以内的所有完数。
提示:借助math模块的sqrt函数(求平方根)
from math import sqrt
n = int(input('输入一个数字:'))
sum = n*-1
k = int(sqrt(n))
for i in range(1,k+1):
if n%i == 0:
sum += n/i
sum += i
if sum == n:
print('YES')
else:
print('NO')
序49:公民类
程序描述
定义公民类,实例成员变量有身份证号、姓名、年龄和性别。定义公民类的派生类:学生类和教师类。学生类增加实例成员变量学号、班级和分数;教师类增加实例变量工号、系别和工资。编写主程序, 定义类的对象,设置对象的实例属性,显示对象的信息。
class Citizen:
def __init__(self,id,name,age,sex):
self.id = id
self.name = name
self.age = age
self.sex = sex
class Student(Citizen):
def __init__(self,id,name,age,sex,stdno,grade,score):
super(Student, self).__init__(id,name,age,sex)
self.stdno = stdno
self.grade = grade
self.score = score
class Teacher(Citizen):
def __init__(self,id,name,age,sex,thno,dept,salary):
super(Teacher, self).__init__(id,name,age,sex)
self.thno = thno
self.dept = dept
self.salary = salary #主程序
c=Citizen('101','zhang',20,'female')
print(c.id,c.name,c.age,c.sex)
s=Student('102','wang',30,'male',1221,'computer12',630)
print(s.id,s.name,s.age,s.sex,end=" ")
print(s.stdno,s.grade,s.score)
t=Teacher('103','li',36,'male',356,'eie',4500)
print(t.id,t.name,t.age,t.sex,end=" ")
print(t.thno,t.dept,t.salary)
程序50:复数类
程序描述
定义一个复数类,包括实部和虚部成员变量、构造方法、以及两个复数的加法、乘法和比 较大小运算符定义。
class Complex:
def __init__(self,r,i):
self.real = r
self.imag = i
def __add__(self, c):
return Complex(self.real + c.real, self.imag + c.imag)
def __mul__(self, c):
return Complex(self.real * c.real- self.imag * c.imag,
self.real * c.imag+ self.imag * c.real)
def __gt__(self, c):
if self.real>c.real:
return True
elif self.real<c.real:
return False
elif self.imag>c.imag:
return True
else:
return False
def show(self):
print(self.real,"+",self.imag, "j")
#主函数
c1 = Complex(3,4)
c2 = Complex(6,-7)
(c1 + c2).show()
(c1 * c2).show()
print(c1 > c2)
程序51:单词计数器
def word_counter(text):
words = text.split()
word_count = len(words)
unique_words = set(words)
print(f"总单词数:{word_count}")
print(f"唯一单词数:{len(unique_words)}")
print("每个单词出现的次数:")
for word in unique_words:
print(f"{word}: {words.count(word)}")
text = "This is a simple word counter program. It counts the number of words in a given text."
word_counter(text)
程序52:文字冒险游戏
def adventure_game():
print("欢迎来到冒险世界!")
print("你发现自己站在两条路交叉的地方。")
while True:
choice = input("你想往左走还是往右走?(左/右):").lower()
if choice == "左":
print("你遇到了一只巨大的龙,不幸被吃掉了。游戏结束!")
break
elif choice == "右":
print("你发现了一箱宝藏!恭喜你获胜!")
break
else:
print("请做出有效的选择。")
adventure_game()
程序53:密码生成器
import random
import string
def generate_password():
characters = string.ascii_letters + string.digits + string.punctuation
password = ''.join(random.choice(characters) for _ in range(12))
return password
print("生成的随机密码:", generate_password())
程序54:文字迷宫游戏
def text_maze_game():
print("欢迎来到文字迷宫游戏!")
position = (0, 0) # 初始位置
end_position = (2, 2) # 终点位置
while position != end_position:
print(f"你现在在位置 {position}")
direction = input("你想往哪个方向移动?(上/下/左/右):").lower()
if direction == "上":
position = (position[0] - 1, position[1])
elif direction == "下":
position = (position[0] + 1, position[1])
elif direction == "左":
position = (position[0], position[1] - 1)
elif direction == "右":
position = (position[0], position[1] + 1)
else:
print("请输入有效的方向。")
print("恭喜!你成功到达终点!")
text_maze_game()
程序55:天气查询程序
import requests
def weather_app(api_key, city):
api_url = f"http://api.openweathermap.org/data/2.5/weather?q={city}&appid={api_key}"
response = requests.get(api_url)
data = response.json()
if response.status_code == 200:
temperature = data['main']['temp']
description = data['weather'][0]['description']
print(f"{city}的天气:温度 {temperature}K,天气状况:{description}")
else:
print(f"无法获取{city}的天气信息。")
# 请替换下面的 API_KEY 和 CITY 为你自己的 OpenWeatherMap API 密钥和城市名称
API_KEY = "your_api_key"
CITY = "Beijing"
weather_app(API_KEY, CITY)
程序56:一个简单的数据库应用
import sqlite3
def create_database():
conn = sqlite3.connect("simple_database.db")
cursor = conn.cursor()
cursor.execute('''CREATE TABLE IF NOT EXISTS users
(id INTEGER PRIMARY KEY, username TEXT, email TEXT)''')
conn.commit()
conn.close()
def add_user(username, email):
conn = sqlite3.connect("simple_database.db")
cursor = conn.cursor()
cursor.execute("INSERT INTO users (username, email) VALUES (?, ?)", (username, email))
conn.commit()
conn.close()
def get_users():
conn = sqlite3.connect("simple_database.db")
cursor = conn.cursor()
cursor.execute("SELECT * FROM users")
users = cursor.fetchall()
conn.close()
return users
# 创建数据库和表
create_database()
# 添加用户
add_user("Alice", "alice@example.com")
add_user("Bob", "bob@example.com")
# 获取用户列表
users = get_users()
print("用户列表:", users)
程序57:字符串排序
#!/usr/bin/python
# -*- coding: UTF-8 -*-
if __name__ == '__main__':
str1 = raw_input('input string:\n')
str2 = raw_input('input string:\n')
str3 = raw_input('input string:\n')
print str1,str2,str3
if str1 > str2 : str1,str2 = str2,str1
if str1 > str3 : str1,str3 = str3,str1
if str2 > str3 : str2,str3 = str3,str2
print 'after being sorted.'
print str1,str2,str3
程序58:猴子分桃子
海滩上有一堆桃子,五只猴子来分。第一只猴子把这堆桃子平均分为五份,多了一个,这只猴子把多的一个扔入海中,拿走了一份。第二只猴子把剩下的桃子又平均分成五份,又多了一个,它同样把多的一个扔入海中,拿走了一份,第三、第四、第五只猴子都是这样做的,问海滩上原来最少有多少个桃子?
#!/usr/bin/python
# -*- coding: UTF-8 -*-
if __name__ == '__main__':
i = 0
j = 1
x = 0
while (i < 5) :
x = 4 * j
for i in range(0,5) :
if(x%4 != 0) :
break
else :
i += 1
x = (x/4) * 5 +1
j += 1
print x
程序59:猜数字
809*??=800*??+9*?? 其中??代表的两位数, 809*??为四位数,8*??的结果为两位数,9*??的结果为3位数。求??代表的两位数,及809*??后的结果。
#!/usr/bin/python
# -*- coding: UTF-8 -*-
a = 809
for i in range(10,100):
b = i * a
if b >= 1000 and b <= 10000 and 8 * i < 100 and 9 * i >= 100:
print b,' = 800 * ', i, ' + 9 * ', i
程序60:读文件
有两个磁盘文件A和B,各存放一行字母,要求把这两个文件中的信息合并(按字母顺序排列), 输出到一个新文件C中。
#!/usr/bin/python
# -*- coding: UTF-8 -*-
if __name__ == '__main__':
import string
fp = open('test1.txt')
a = fp.read()
fp.close()
fp = open('test2.txt')
b = fp.read()
fp.close()
fp = open('test3.txt','w')
l = list(a + b)
l.sort()
s = ''
s = s.join(l)
fp.write(s)
fp.close()
程序61:类型转换
列表转换为字典
#!/usr/bin/python
# -*- coding: UTF-8 -*-
i = ['a', 'b']
l = [1, 2]
print dict([i,l])
程序62:进制转换-八进制转十进制
#!/usr/bin/python
# -*- coding: UTF-8 -*-
if __name__ == '__main__':
n = 0
p = raw_input('input a octal number:\n')
for i in range(len(p)):
n = n * 8 + ord(p[i]) - ord('0')
print n
程序63:求数
求0—7所能组成的奇数个数。
程序分析:
组成1位数是4个。
组成2位数是7*4个。
组成3位数是7*8*4个。
组成4位数是7*8*8*4个。
#!/usr/bin/python
# -*- coding: UTF-8 -*-
if __name__ == '__main__':
sum = 4
s = 4
for j in range(2,9):
print sum
if j <= 2:
s *= 7
else:
s *= 8
sum += s
print 'sum = %d' % sum
程序64:字符串连接
#!/usr/bin/python
# -*- coding: UTF-8 -*-
delimiter = ','
mylist = ['Brazil', 'Russia', 'India', 'China']
print delimiter.join(mylist)
程序65:两个字符串连接
#!/usr/bin/python
# -*- coding: UTF-8 -*-
if __name__ == '__main__':
a = "kkkhngil"
b = "qwertyuiop"
# 连接字符串
c = a + b
print c
程序66:数学分析-求9的位数
输入一个奇数,然后判断最少几个 9 除于该数的结果为整数。
程序分析:999999 / 13 = 76923。
#!/usr/bin/python
# -*- coding: UTF-8 -*-
if __name__ == '__main__':
zi = int(raw_input('输入一个数字:\n'))
n1 = 1
c9 = 1
m9 = 9
sum = 9
while n1 != 0:
if sum % zi == 0:
n1 = 0
else:
m9 *= 10
sum += m9
c9 += 1
print '%d 个 9 可以被 %d 整除 : %d' % (c9,zi,sum)
r = sum / zi
print '%d / %d = %d' % (sum,zi,r)
程序67:结构体的初步学习-结构体变量传递
#!/usr/bin/python
# -*- coding: UTF-8 -*-
if __name__ == '__main__':
class student:
x = 0
c = 0
def f(stu):
stu.x = 20
stu.c = 'c'
a= student()
a.x = 3
a.c = 'a'
f(a)
print a.x,a.c
程序68:打印
读取7个数(1—50)的整数值,每读取一个值,程序打印出该值个数的*
#!/usr/bin/python
# -*- coding: UTF-8 -*-
if __name__ == '__main__':
n = 1
while n <= 7:
a = int(raw_input('input a number:\n'))
while a < 1 or a > 50:
a = int(raw_input('input a number:\n'))
print a * '*'
n += 1
程序69:数据加密
某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。
#!/usr/bin/python
# -*- coding: UTF-8 -*-
from sys import stdout
if __name__ == '__main__':
a = int(raw_input('输入四个数字:\n'))
aa = []
aa.append(a % 10)
aa.append(a % 100 / 10)
aa.append(a % 1000 / 100)
aa.append(a / 1000)
for i in range(4):
aa[i] += 5
aa[i] %= 10
for i in range(2):
aa[i],aa[3 - i] = aa[3 - i],aa[i]
for i in range(3,-1,-1):
stdout.write(str(aa[i]))
程序70:列表学习
#!/usr/bin/python
# -*- coding: UTF-8 -*-
#list
#新建列表
testList=[10086,'中国移动',[1,2,4,5]]
#访问列表长度
print len(testList)
#到列表结尾
print testList[1:]
#向列表添加元素
testList.append('i\'m new here!')
print len(testList)
print testList[-1]
#弹出列表的最后一个元素
print testList.pop(1)
print len(testList)
print testList
#list comprehension
#后面有介绍,暂时掠过
matrix = [[1, 2, 3],
[4, 5, 6],
[7, 8, 9]]
print matrix
print matrix[1]
col2 = [row[1] for row in matrix]#get a column from a matrix
print col2
col2even = [row[1] for row in matrix if row[1] % 2 == 0]#filter odd item
print col2even
程序80:时间函数学习-1
#!/usr/bin/python
# -*- coding: UTF-8 -*-
if __name__ == '__main__':
import time
print time.ctime(time.time())
print time.asctime(time.localtime(time.time()))
print time.asctime(time.gmtime(time.time()))
程序81:时间函数学习-2
#!/usr/bin/python
# -*- coding: UTF-8 -*-
if __name__ == '__main__':
import time
start = time.time()
for i in range(3000):
print i
end = time.time()
print end - start
程序82:时间函数学习-3
#!/usr/bin/python
# -*- coding: UTF-8 -*-
if __name__ == '__main__':
import time
start = time.clock()
for i in range(10000):
print i
end = time.clock()
print 'different is %6.3f' % (end - start)