python基础编程:python下10个简单实例代码
注意:我⽤的python2.7,⼤家如果⽤Python3.0以上的版本,请记得在print()函数哦!如果因为版本问题评论的,不做回复哦
1.题⽬:有1、2、3、4个数字,能组成多少个互不相同且⽆重复数字的三位数?都是多少?
程序分析:可填在百位、⼗位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满⾜条件的排列。
verilog循环移位运算符程序源代码:
# -*- 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 来计算表达式的值,也就是奖⾦总数。就是把奖⾦叠加起来,具体算法还是要在纸上计算,这种⽅法适⽤于初学编码的⼈,⽐如我,⽤最笨的数学思路解决问题,就是说在数学上你是按照什么⽅法做的,然后把他转化成代码,就⽐较容易理解了。
# -*- 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
elif I <= 60 and I > 100:
e = 2 + I * 0.015
print e
else:
f = 2.95 + I * 0.01
print f
⽅法⼆:这种⽅法就⽐较难懂了,适合于基础好的⼈
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时需考虑多加⼀天。
思路:先把输⼊的⽇期进⾏分割,分割成年,⽉,⽇三个数字,再按照实际情况依次编写。
# -*- coding: UTF-8 -*-
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
print "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:\n'))
l.append(x) #这⾥⽤append()函数,意思是追加元素
l.sort()
print l
程序分析⼆:⽤⼀个变量来存储最⼩值,三个数进⾏⽐较后两两交换,这是最常⽤的思路。
x = input("input a num:")
y = input("input a num:")小程序的textarea固定程度
z = input("input a num:")
temp = 0
if x < y:
temp = x
x = y学python编程入门
y = temp
if x < z:
temp = x
x = z
z = temp
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:")
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
输出:[1, 2, 3, 4, 5, 6]
⽅法三:使⽤列表[:]。切⽚的⽅法,⼤家都知道如果不指定start和end,则表⽰输出该列表的所以元素。
# -*- coding: UTF-8 -*-
a = [1, 2, 3] #把列表a复制到列表b
b = a[:]
print b
7.题⽬:输出9*9乘法⼝诀表。
程序分析:分⾏与列考虑,共9⾏9列,i控制⾏,j控制列。如果不要求格式的话,就简单了,可以任意格式输出,如下:
for i in range(1,10):
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)
= 3 + 2
相对路径上一级目录= 5
..... ...
所以,当 n >= 2 时,表达式为f(n) = f(n-1) + f(n-2)
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)
= 3 + 2
= 5
..... ...
所以,当 n >= 2 时,表达式为f(n) = f(n-1) + f(n-2)
⽅法⼀:
def fib(n):
a,b = 1,1
for i in range(n-1):
a,b = b,a+b
return a
# 输出了第10个斐波那契数列
print fib(10)
⽅法⼆:
# -*- coding: UTF-8 -*-
# 使⽤递归
def fib(n):
if n==1 or n==2:
return 1
return fib(n-1)+fib(n-2)
# 输出了第10个斐波那契数列
print fib(10)
⽅法三:如果你需要输出指定个数的斐波那契数列,可以使⽤以下代码:
# -*- coding: UTF-8 -*-
def fib(n):
if n == 1:
return [1]
if n == 2:
return [1, 1]
fibs = [1, 1]
for i in range(2, n):
fibs.append(fibs[-1] + fibs[-2])
return fibs
# 输出前 10 个斐波那契数列
print fib(10)
10.题⽬:古典问题:有⼀对兔⼦,从出⽣后第3个⽉起每个⽉都⽣⼀对兔⼦,⼩兔⼦长到第三个⽉后每个⽉⼜⽣⼀对兔⼦,假如兔⼦都不死,问每个⽉的兔⼦总数为多少?
程序分析:经过计算和寻规律得到,兔⼦的规律为数列1,1,2,3,5,8,13,21….典型的斐波那契数列,这就是为什么我要把斐波那契数列数列放在第九题的原因,那么根据上⼀题的⽅法三,我们就⾮常轻松的求得每⽉兔⼦的数量。
此外,还有⼀种⽐较漂亮的输出:
# -*- coding: UTF-8 -*-
f1 = 1
f2 = 1
for i in range(1,21):
print '%12ld %12ld' % (f1,f2),
if (i % 3) == 0:
print ''
f1 = f1 + f2
f2 = f1 + f2
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论