本文实例全部来自runoob.com的Python基础教程
实例1
题目:有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
分析:通过三层循环,将个、十、百位上的数分别循环一次,当其中任意两位相同时,则跳过,当各位上的数都不同时,输出
# 代码
count = 0
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 k != i :
print(i,j,k)
count += 1
print(count)
# 输出
1 2 3
1 2 4
1 3 2
1 3 4
1 4 2
1 4 3
2 1 3
2 1 4
2 3 1
2 3 4
2 4 1
2 4 3
3 1 2
3 1 4
3 2 1
3 2 4
3 4 1
3 4 2
4 1 2
4 1 3
4 2 1
4 2 3
4 3 1
4 3 2
24
实例2
题目: 企业发放的奖金根据利润提成。利润(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,求应发放奖金总数?
分析:请利用数轴来分界,定位。注意定义时需把奖金定义成长整型。
# 代码
i = int (input('请输入当月利润I(单位/万元):'))
arr = [100,60,40,20,10,0]
rat = [0.01,0.015,0.03,0.05,0.075,0.1]
r = 0
for j in range(0,6):
if i > arr [j]:
r += ( i - arr[j] ) * rat[j]
print ((i-arr[j])*rat[j])
i=arr[j]
print (r)
#输出
请输入当月利润I(单位/万元):120
0.2
0.6
0.6
1.5
1.0
3.9
实例3
题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
分析:假设该数为 x。
1、则:x + 100 = n2, x + 100 + 168 = m2
2、计算等式:m2 - n2 = (m + n)(m - n) = 168
3、设置: m + n = i,m - n = j,i * j =168,i 和 j 至少一个是偶数
4、可得: m = (i + j) / 2, n = (i - j) / 2,i 和 j 要么都是偶数,要么都是奇数。
5、从 3 和 4 推导可知道,i 与 j 均是大于等于 2 的偶数。
6、由于 i * j = 168, j>=2,则 1 < i < 168 / 2 + 1。
7、接下来将 i 的所有数字循环计算即可。
#代码
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 :
m = (i + j) / 2
n = (i - j) / 2
x = n * n - 100
print(x)
#输出
-99.0
21.0
261.0
1581.0
实例4
题目: 输入某年某月某日,判断这一天是这一年的第几天?
分析: 以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊情况,闰年且输入月份大于2时需考虑多加一天
# 代码
year = int(input ("请输入年份:"))
mon = int(input ("请输入月份:"))
day = int(input ("请输入日期:"))
#非闰年每月末是第几天
months = (0,31,59,90,12,151,181,212,243,273,304,334)
sum = 0
#判断闰年
if (year % 400 == 0) or ((year % 4 == 0) and (year % 100 != 0)):
if mon > 2 :
sum = 1
if 0 < mon <= 12 :
sum = months[mon-1] + day + sum
print("这是第%d天。"%sum)
# 输出
请输入年份:2015
请输入月份:6
请输入日期:7
这是第158天。
实例5
题目: 输入三个整数x,y,z,请把这三个数由小到大输出
分析: 我们想办法把最小的数放到x上,先将x与y进行比较,如果x>y则将x与y的值进行交换,然后再用x与z进行比较,如果x>z则将x与z的值进行交换,这样能使x最小
# 代码
l = []
for i in range (0,3):
l.append(int(input('integer:')))
l.sort()
print(l)
# 输出
integer:6
integer:5
integer:7
[5, 6, 7]
实例6
题目:斐波那契数列。
程序分析:斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、……。在数学上,费波那契数列是以递归的方法来定义
# 代码
def fib(x):
if x == 1:
return 1
elif x == 2:
return 1
else:
return fib(x - 1) + fib(x - 2)
print(fib(int(input("请输入要求第几位数:"))))
# 输出
请输入要求第几位数:10
55
实例7
题目:将一个列表的数据复制到另一个列表中。
程序分析:使用列表切片
# 代码
a = [1,2,3]
b = a[:]
print(b)
#输出
[1, 2, 3]
实例8
题目:输出 9*9 乘法口诀表。
程序分析:分行与列考虑,共9行9列,i控制行,j控制列。
# 代码
for i in xrange(1, 10):
for j in xrange(1, i + 1):
print("%d*%d=%d" % (i, j, i * j), end=" ")
print("\n")
# 输出
1*1=1
2*1=2 2*2=4
3*1=3 3*2=6 3*3=9
4*1=4 4*2=8 4*3=12 4*4=16
5*1=5 5*2=10 5*3=15 5*4=20 5*5=25
6*1=6 6*2=12 6*3=