第一题~
有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
这一题的大致思路还是很清晰的,三个for就可以搞定,问题是怎么确保不重复。当然,这也很简单,直接加个判断即可。
那么,理论存在,实践开始~
'''
有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
'''
nums = [1,2,3,4]
for i in nums:
for j in nums:
for k in nums:
if i == j or j == k or i == k:
pass
else:
print(i*100+j*10+k)
第二题~
企业发放的奖金根据利润提成。利润(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,求应发放奖金总数?
emmm……把题目分析一下就可以发现,这是一道纯纯的if构成的题,那么,让我们开始吧!
'''
企业发放的奖金根据利润提成。利润(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,求应发放奖金总数?
'''
profit = int(input('请输入利润:'))
if profit <= 100000:
print(profit*0.1)
elif 100000 < profit <= 200000:
print(100000*0.1+(profit-100000)*0.075)
elif 200000 < profit <= 400000:
print(100000*(0.1+0.075)+(profit-200000)*0.05)
elif 400000 < profit <= 600000:
print(100000*(0.1+0.075)+200000*0.05+(profit-400000)*0.03)
elif 600000 < profit <= 1000000:
print(100000*(0.1+0.075)+200000*(0.05+0.03)+(profit-600000)*0.015)
else:
print(100000*(0.1+0.075)+200000*(0.05+0.03)+400000*0.015+(profit-1000000)*0.01)
告诉我,什么才叫真正的穷举法啊!(战术后仰)
后来看了答案,发现有更棒的答案了,在此也一并贴出来吧
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又是一个完全平方数,请问该数是多少?
这还不简单,来,上代码
print(21,261,1581)
等等,先别打我,开个玩笑嘛,完整的代码应该是这样的:
'''
一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
'''
for i in range(10000):
if ((i+100)**0.5) % 1 == 0 and ((i+268)**0.5) % 1 == 0:
print(i)
反思一下,我主要有两点问题:第一,这个range(10000)很明显不对劲,我不知道这个数的范围,那我就不能给他定义范围,这一次是运气好,没超过两千,那换了数字和运算方式之后呢?这一点值得反思。第二点,这个代码过于耗费内存,肯定是不适用的,还需要再改。
这里是正确答案
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)
好啦,今天就暂时告一段落了吧