只适用于python3以上版本,有改良请指教!!
from cmath import sqrt #导入sqrt
from functools import reduce
# 题目:有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
# 程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满足条件的排列。
def t1():
for i in range(1,5):
for p in range(1,5):
for o in range(1,5):
if (i!= p) and (i != o) and (p != o):
print(i,p,o)
# 企业发放的奖金根据利润提成。利润(I)低于或等于10万元时,奖金可提10%;利润高于10万元,
# 低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;20万到40万之间时,高于20万元的部分,
# 可提成5%;40万到60万之间时高于40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,
# 高于100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?
def t2():
i = int(input('净利润:'))
arr = [1000000, 600000, 400000, 200000, 100000, 0]
rat = [0.01, 0.015, 0.03, 0.05, 0.075, 0.1]
r = 0
for idx in range(0, 6):
if i > arr[idx]:
r += (i - arr[idx]) * rat[idx]
print((i - arr[idx]) * rat[idx])
i = arr[idx]
print(r)
#一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
def t3():
for i in range(1,85):
if 168 % i == 0:
j = 168 / i
if i > j and (i + j) % 2 == 0 and (i - j) % 2 == 0 :
n = (i - j) / 2
x = n * n - 100
print(x)
#输入某年某月某日,判断这一天是这一年的第几天?
def t4():
year = int(input('year:'))
month = int(input('month:'))
day = int(input('day:'))
sum = 0
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('这是第{}天'.format(sum))
#输入三个整数x,y,z,请把这三个数由小到大输出。
def t5():
l=[]
for i in range(3):
a = int(input('输入数值:'))
l.append(a)
l.sort() #根据sort函数输出
print(l)
#斐波那契数列。 -- 使用递归方法实现
def t6():
def f(n):
if n==1 or n==2:
return 1
return f(n-1)+f(n-2)
print(f(6))
#将一个列表的数据复制到另外一个列表中
def t7():
a = range(10)
b = a[:]
for i in b:
print(i)
#输出 9*9 乘法口诀表。
def t8():
for i in range(1,10): #控制a的输出
for j in range(1,i+1): #控制b的输出
print(j,'*',i,'=',i*j,' ',end='')
print()
#暂停一秒输出。
def t9():
from time import sleep
sleep(1)
print('asd')
#暂停一秒输出,并格式化当前时间。
def t10():
import time
print(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time()))) #
# 暂停一秒
time.sleep(1)
print(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time())))
#古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
def t11():
f1 = 1
f2 = 1
for i in range(1, 22):
print('%12ld %12ld' % (f1, f2),)
if (i % 3) == 0:
print('')
f1 = f1 + f2
f2 = f1 + f2
#判断101-200之间有多少个素数,并输出所有素数。用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。
#sqrt需要导入这个模块,是取平方根
def t12():
h = 0
leap = 1
from math import sqrt
for m in range(101, 201):
k =