|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 铁棍阿童木 于 2017-9-16 18:26 编辑
动动手1:水仙花问题。(我用了最笨的办法,有两套方案)
方案一:
# 计算并输出100至999之间所有的水仙花数
"""算法的难点在于,如何对三位数的每一个位次的数值采取幂运算。
我是用的最原始的办法,将该三位数与100进行floor除法,得到百位
数的值,以此类推分别获得十位数、个位数的数值,然后进行立方和
运算。
"""
number = 100
while number <= 999:
hun_digit = number // 100
ten_digit = (number-hun_digit*100) // 10
sin_digit = number - hun_digit * 100 - ten_digit * 10
if number == hun_digit ** 3 + ten_digit ** 3 + sin_digit ** 3:
print(number,end = " ")
number += 1
print("以上是100到999之间所有的水仙花数!")
方案二:
for hun_digit in range(1,10):
for ten_digit in range(0,10):
for sin_digit in range(0,10):
if hun_digit * 100 + ten_digit * 10 + sin_digit == hun_digit ** 3 + ten_digit ** 3 + sin_digit ** 3:
print(hun_digit * 100 + ten_digit * 10 + sin_digit,end=" ")
print("以上为所有三次幂水仙花数!")
个人来说喜欢方案二,至少简洁一点,三个for循环嵌套。
动动手2.三色球问题(我的解决方案居然跟小甲鱼一模一样)
源代码如下:
#3个红球,3个黄球,6个蓝球,任意取出8个有多少种颜色组合
#在这里设置一个初始变量用于记录颜色组合总数,初始值为0.
Tricolore = 0
"""
根据题意:使用三个嵌套的for循环来遍历所有组合,红球全部组合为0个、1个、2个、3个;
黄球全部的组合为0个、1个、2个、3个;蓝球全部的组合为2个、3个、4个、5个、6个(蓝球至少要2个,否则组合不成立);
三种颜色的球分别进行全排列组合计算,球的个数等于8就是合符条件的颜色组合,程序如下:
"""
for red in range(4):
for yellow in range(4):
for blue in range(2,7):
if red + yellow + blue == 8:
print(str(red) + "红" + str(yellow) + "黄" + str(blue) + "蓝")
Tricolore += 1
print("三色球问题计算完毕,共计 " + str(Tricolore) + " 种颜色组合")
|
-
|