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,求应发放奖金总数?

    程序分析:请利用数轴来分界,定位。注意定义时需把奖金定义成长整型。

    程序源代码:

#!/usr/bin/python
# -*- 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
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

    以上实例输出结果为:

净利润:120000
1500.0
10000.0
11500.0

    再来看其他例子:

    使用if...elif...else语句逐一判断:

#!/usr/bin/python
# -*- coding: UTF-8 -*- import sys reload(sys)
sys.setdefaultencoding('utf-8') x = int(raw_input("净利润:")) if x<=100000:
bonus=x*0.1
print u"奖金:",bonus,u"元"
elif 100001<x<=200000:
bonus=10000+(x-100000)*0.075
print u"奖金:",bonus,u"元"
elif 200001<x<=400000:
bonus=10000+7500+(x-200000)*0.05
print u"奖金:",bonus,u"元"
elif 400001<x<=600000:
bonus=10000+7500+10000+(x-400000)*0.03
print u"奖金:",bonus,u"元"
elif 600001<x<=1000000:
bonus=10000+7500+10000+6000+(x-600000)*0.015
print u"奖金:",bonus,u"元"
elif 600001<x<=1000000:
bonus=10000+7500+10000+6000+6000+(x-600000)*0.01
print u"奖金:",bonus,u"元"

    还有一种:

#!/usr/bin/python
# -*- coding: UTF-8 -*- i = int(raw_input('净利润:'))
I = [1000000,600000,400000,200000,100000,0]
r = [0.01,0.015,0.03,0.05,0.075,0.1]
for j in range(len(I)):
if i > I[j]:
b = [0,0,0,0,0,0]
b[j] = i -I[j]
for k in range(j+1,len(I)):
b[k] = I[k-1]
bonus = sum(map(lambda (i1,i2): i1 * i2,zip(b,r)))
break
print '奖金:',bonus

    使用切片:

#!/usr/bin/python
# -*- coding: UTF-8 -*- value=int(raw_input('please input profit: '))
list1=[1000000,600000,400000,200000,100000,0]
list2=[0.01,0.015,0.03,0.05,0.075,0.1]
list3=[400000,200000,200000,100000,100000]
for i in range(6):
if value >list1[i]:
v1=(value-list1[i])*list2[i]
print v1
list2_new=list2[i+1:6]
list3_new=list3[i:5]
v2=sum(map(lambda (x,y):x*y,zip(list2_new,list3_new)))
print v2
print v1+v2
break

    Python中的列表可以嵌套,这样外层列表就跟数组一样,内层的是对象。不过Python的列表数据类型不一定一样,更加灵活了:

#!/usr/bin/python3

Bonus = 0;
BonusRateList = [[100,0.010],[60,0.015],[40,0.030],[20,0.050],[10,0.075],[0,0.100]]; Profit = 120000;
Profit /= 10000; for i in range(0, len(BonusRateList)) :
if (Profit > BonusRateList[i][0]) :
Bonus += ((Profit - BonusRateList[i][0]) * BonusRateList[i][1]);
Profit = BonusRateList[i][0]; print (Bonus * 10000);

    使用字典控制利润与提成比例的匹配:

#!/user/bin/env python
# coding=utf-8 # 计算公司的年度奖金,单位:万元
num = int(raw_input("请输入今年的公司利润:"))
obj = {100: 0.01, 60: 0.015, 40: 0.03, 20: 0.05, 10: 0.075, 0: 0.1}
keys = obj.keys()
keys.sort()
keys.reverse()
r = 0
for key in keys:
if num > key:
r += (num - key) * obj.get(key)
num = key
print "今年的奖金为:", r, "万元。"

    Python3 测试方法:

def  get_reward(I):
    rewards = 0
    if I <= 10:
        rewards = I * 0.1     elif (I > 10) and (I <= 20):
        rewards = (I - 10) * 0.075 + get_reward(10)     elif (I > 20) and (I <= 40):
        rewards = (I - 20) * 0.05 + get_reward(20)     elif (I > 40) and (I <= 60):
        rewards = (I - 40) * 0.03 + get_reward(40)     elif (I > 60) and (I <= 100):
        rewards = (I - 60) * 0.015 + get_reward(60)     else:
        rewards = get_reward(100) + (I - 100) * 0.01     return rewards if __name__ == '__main__':
    i = 120000
    print("净利润:", i)
    print("发放的奖金为:", get_reward(i / 10000) * 10000)

    可以同时使用两种方式创建生成器: 生成器推导式使用yield关键字构造生成器函数, 如下所示:

#使用两种方式创建生成器
a=[100,60,40,20,10,0]
b=[0.01,0.015,0.03,0.05,0.075,0.1] #生成器函数
def f(x):
for i in range(len(a)):
if n>a[i]:
#生成器推导式
c=(a[j]-a[j+1] for j in range(i,len(a)-1))
break
r=sum(map(lambda x,y:x*y,b[i:],[(n-a[i])]+list(c)))
yield r*10000 k=int(input("是否继续计算奖金?是:1, 否:0\n"))
while k:
n=int(input('请输入利润,单位(万元):'))
print('应发奖金为:',next(f(n)),'(元)')
print()
k=int(input("是否继续计算奖金?是:1, 否:0\n"))
print('感谢使用,程序结束!')

最后一个我感觉比较有意思,其它的怎么说呢,万变不离其宗吧。大家可以看下,大神们的代码习惯。如果感觉不错的话,请多多点赞支持哦。。。

python2.7练习小例子(二)的更多相关文章

  1. python2.7练习小例子(二十九)

        29):1.题目:按相反的顺序输出列表的值. #!/usr/bin/python # -*- coding: UTF-8 -*- a = ['one', 'two', 'three'] for ...

  2. python2.7练习小例子(十二)

        12):题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身.例如:153是一个"水仙花数" ...

  3. python2.7练习小例子(二十七)

        27):题目:一个5位数,判断它是不是回文数.即12321是回文数,个位与万位相同,十位与千位相同.      #!/usr/bin/python # -*- coding: UTF-8 -* ...

  4. python2.7练习小例子(二十八)

    28):题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母.     程序分析:用情况语句比较好,如果第一个字母一样,则判断用情况语句或if语句判断第二个字母. ...

  5. python2.7练习小例子(二十四)

        24):1.题目:利用递归方法求5!.     程序分析:递归公式:fn=fn_1*4! #!/usr/bin/python # -*- coding: UTF-8 -*- def fact( ...

  6. python2.7练习小例子(二十三)

        23):题目:求1+2!+3!+...+20!的和.     程序分析:此程序只是把累加变成了累乘. #!/usr/bin/python # -*- coding: UTF-8 -*- n = ...

  7. python2.7练习小例子(八)

        8):题目:输出 9*9 乘法口诀表.     程序分析:分行与列考虑,共9行9列,i控制行,j控制列.     程序源代码: #!/usr/bin/python # -*- coding: ...

  8. python2.7练习小例子(七)

        7):题目:将一个列表的数据复制到另一个列表中.     程序分析:使用列表[:].     程序源代码: #!/usr/bin/python # -*- coding: UTF-8 -*- ...

  9. python2.7练习小例子(十八)

    19):题目:一个数如果恰好等于它的因子之和,这个数就称为"完数".例如6=1+2+3.编程找出1000以内的所有完数.      #!/usr/bin/python # -*- ...

  10. python2.7练习小例子(十七)

        17):题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字.例如2+22+222+2222+22222(此时共有5个数相加),几个数相加由键盘控制.     程序分析: ...

随机推荐

  1. 区间的连续段~ST表(模板题)

    链接:https://www.nowcoder.com/acm/contest/82/B来源:牛客网 时间限制:C/C++ 7秒,其他语言14秒 空间限制:C/C++ 262144K,其他语言5242 ...

  2. Django REST framework+Vue 打造生鲜超市(四)

    五.商品列表页 5.1.django的view实现商品列表页 (1)goods/view_base.py 在goods文件夹下面新建view_base.py,为了区分django和django res ...

  3. ActiveMQ学习系列(三)----下载github源码并编译

    前记:坚持使用官网的资源去学习是挺痛苦的一个过程,昨天瞎溜达了一天,也没看到有系统性的学习文章,倒是发现了github上的ActiveMq项目. 地址:https://github.com/apach ...

  4. HDU1028【母函数】

    题目:给你数n,问n可以有哪些组成方案(这些n的数字个数不超过n),母函数模板题 #include <cstdio> #include <cstring> #include & ...

  5. 南京邮电大学java程序设计作业在线编程第三次作业

    王利国的"Java语言程序设计第3次作业(2018)"详细 作业结果详细 总分:100 选择题得分:60  1. 设有如下定义语句: String s1="My cat& ...

  6. requests post一个json数据

    # post一个json数据 import requests headers={ "Accept":"application/json, text/plain, */*& ...

  7. chrome浏览器再次打开黑屏一段时间

    打开chrome设置 最下面-显示高级设置 再拉到最下面-使用硬件加速模式(把勾去掉)

  8. CodeForces 914DBash and a Tough Math Puzzle(线段树的骚操作)

    D. Bash and a Tough Math Puzzle time limit per test 2.5 seconds memory limit per test 256 megabytes ...

  9. C++因继承引发的隐藏与重写

    在区分隐藏和重写之前,先来理一理关于继承的东西... [继承] 继承是面向对象复用的重要手段.通过继承定义一个类,继承是类型之间的关系建模,共享公有的东西,实现各自本质不同的东西.简单的说,继承就是指 ...

  10. 探寻 webpack 插件机制

    webpack 可谓是让人欣喜又让人忧,功能强大但需要一定的学习成本.在探寻 webpack 插件机制前,首先需要了解一件有意思的事情,webpack 插件机制是整个 webpack 工具的骨架,而 ...