python程序实例源代码-python下10个简单实例代码
注意:我⽤的python2.7,⼤家如果⽤Python3.0以上的版本,请记得在print()函数哦!如果因为版本问题评论的,不做回复哦
1.题⽬:有1、2、3、4个数字,能组成多少个互不相同且⽆重复数字的三位数?都是多少?
程序分析:可填在百位、⼗位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满⾜条件的排列。
程序源代码:
# -*- coding: UTF-8 -*-
for i in range(1,5):
for j in range(1,5):
for k in range(1,5):
if (i != j) and (i != k) and (j != k):
print i,j,k
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 来计算表达式的值,也就是奖⾦总数。就是把奖⾦叠加起来,具体算法还是要在纸上计算,这种⽅法适⽤于初学编码的⼈,⽐如我,⽤最笨的数学思路解决问题,就是说在数学上你是按照什么⽅法做的,然后把他转化成代码,就⽐较容易理解了。
游标%rowcount# -*- coding: UTF-8 -*-
while True:
I = input("pls input the lirun:")
if I <= 10:
a = I * 0.01
print a
elif I <= 20 and I > 10:
b =0.25 + I * 0.075
print b
elif I <= 40 and I > 20:
c = 0.75 + I * 0.05
print c
elif I <= 60 and I > 40:
d = 0.95 + I * 0.03
print d
print e
else:
f = 2.95 + I * 0.01
print f
⽅法⼆:这种⽅法就⽐较难懂了,适合于基础好的⼈。
# -*- coding: UTF-8 -*-
I = int(raw_input('净利润:'))
#这应该就是各个分界值了,把它们放在列表⾥⽅便访问
arr = [1000000,600000,400000,200000,100000,0]
#这是各个分界值所对应的奖⾦⽐例值
rat = [0.01,0.015,0.03,0.05,0.075,0.1]
#这是总奖⾦的初始值
r = 0
#有6个分界值当然要循环6次
for idx in range(0,6):
if I > arr[idx]:
r = r + (I - arr[idx]) * rat[idx]
print (I - arr[idx]) * rat[idx]
I = arr[idx]
print r
3.题⽬:⼀个整数,它加上100和加上268后都是⼀个完全平⽅数,请问该数是多少?
程序分析:在10000以内判断,将该数加上100后再开⽅,加上268后再开⽅,如果开⽅后的结果满⾜如下条件,即是结果。这⾥要⽤到数学中的开⽅函数 sqrt。
# -*- coding: UTF-8 -*-
import math
for i in range(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
4.题⽬:输⼊某年某⽉某⽇,判断这⼀天是这⼀年的第⼏天?
程序分析:以3⽉5⽇为例,应该先把前两个⽉的加起来,然后再加上5天即本年的第⼏天,特殊情况,闰年且输⼊⽉份⼤于3时需考虑多加⼀天。
x = raw_input("请输⼊⽇期,⽐如20160506:")
year = int(x[:4])
month = int(x[4:6])
day = int(x[6:8])
month_day = [31,28,31,30,31,30,31,31,30,31,30,31]
data = sum(month_day[:(month-1)],day)
if (year % 4 == 0 and year % 100 != 0) or (year % 400 == 0):
if month > 2:
data = data + 1
heteprint "it is the %dth day"% (data)
5.题⽬:输⼊三个整数x,y,z,请把这三个数由⼩到⼤输出。
电池视频模板网站
程序分析⼀:我们想办法把最⼩的数放到x上,先将x与y进⾏⽐较,如果x>y则将x与y的值进⾏交换,然后再⽤x与z进⾏⽐较,如果x>z则将x与z的值进⾏交换,这样能使x最⼩。
# -*- coding: UTF-8 -*-
l = []
for i in range(3):
x = int(raw_input('integer: '))
l.append(x) #这⾥⽤append()函数,意思是追加元素
l.sort()
print l
程序分析⼆:⽤⼀个变量来存储最⼩值,三个数进⾏⽐较后两两交换,这是最常⽤的思路。
# -*- coding: UTF-8 -*-
x = input("input a num:")
y = input("input a num:")
z = input("input a num:")
temp = 0
if x < y:
temp = x
x = y
y = temp
if x < z:
temp = x
if y < z:
temp = y
y = z
z = temp
print z,y,x #由于上⾯是由⼩到⼤来⽐较和交换的,所以这⾥需要逆序输出
程序分析三:⽤函数sort进⾏排序,sort函数可以把数字按照从⼩到⼤的顺序进⾏重新排列。
# -*- coding: UTF-8 -*-
x = input("input a num:")
y = input("input a num:")
z = input("input a num:")python分支结构实例
y = [x,y,z] #注意,这⾥只能是列表,不能是元组,因为元组是不可改变的,你懂得!!
y.sort()
print y
6.题⽬:将⼀个列表的数据复制到另⼀个列表中。
注意: 有些同学想到使⽤append()函数,这⾥要特别注意,append()函数是每次追加⼀个元素,如果使⽤append()函数,会把需要追加的那个列表当成⼀个数据来使⽤,不信你看下⾯这个:
⽅法⼀:
# -*- coding: UTF-8 -*-
l1 = [1,2,3]
l2 = [4,5,6]
l1.append(l2)
print l1
输出:[1, 2, 3, [4, 5, 6]]
⽅法⼆:使⽤“+”来连接两个列表,即就是把l2列表的数据复制到l1列表中。
# -*- coding: UTF-8 -*-
l1 = [1,2,3]
l2 = [4,5,6]
print l1 + l2
跟兄弟连学php配套视频教程输出:[1, 2, 3, 4, 5, 6]
⽅法三:使⽤列表[:]。切⽚的⽅法,⼤家都知道如果不指定start和end,则表⽰输出该列表的所以元素。
# -*- coding: UTF-8 -*-
a = [1, 2, 3] #把列表a复制到列表b
7.题⽬:输出9*9乘法⼝诀表。
程序分析:分⾏与列考虑,共9⾏9列,i控制⾏,j控制列。如果不要求格式的话,就简单了,可以任意格式输出,如下:
# -*- coding: UTF-8 -*-
for i in range(1,10):
python基础代码大全加翻译
for j in range(1,10):
x = i * j
print "%d * %d = %d" % (i,j,x)
如果需要考虑输出格式,我们后⾯的⽂章会讲到,嘿嘿。
8.题⽬:暂停⼀秒输出。
程序分析:暂停时间的函数为 time.sleep(),此处可随意举例,列表,元组,字典均可。
# -*- coding: UTF-8 -*-
import time
d = {"a":1,"b":2}
for i in d:
print i
time.sleep(1) #暂停⼀秒输出
9.题⽬:斐波那契数列。
程序分析:斐波那契数列(Fibonacci sequence),⼜称黄⾦分割数列,指的是这样⼀个数列:0、1、1、2、3、5、8、13、21、34、……。
在数学上,费波那契数列是以递归的⽅法来定义:
n = 1 时 f(1) = 1
n = 2 时 f(2) = 1
n = 3 时 f(3) = f(3-1) + f(3-2)
= f(2) + f(1)
= 1 + 1
= 2
n = 4 时 f(4) = f(4-1) + f(4-2)
= f(3) + f(2)
= 2 + 1
= 3
n = 5 时 f(5) = f(5-1) + f(5-2)
= f(4) + f(3)

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。