問題:
編寫一個在1,2,…,9(順序不能變)數字之間插入+或-或什么都不插入,使得計算結果總是100的程序,并輸出所有的可能性。例如:1 + 2 + 34–5 + 67–8 + 9 = 100。
from functools import reduceoperator = { 1: '+', 2: '-', 0: ''}base = ['1', '2', '3', '4', '5', '6', '7', '8', '9']def isHundred(num): #轉化為8位3進制數,得到運算符數組 arr = [] for index in range(8): index = 7 - index arr.append(num // (3 ** index)) num -= (num // (3 ** index)) * (3 ** index) arr = map(lambda x: operator[x], arr) #合并得到運算式 formula = reduce(lambda x, y: x + y, zip(base, arr)) formula = list(formula) formula.append('9') formula = ''.join(formula) #計算運算式結果 res = eval(formula) return res, formulaif __name__ == '__main__': #所有可能的結果 total = 3 ** 8 for i in range(total): res, formula = isHundred(i) if res == 100: print(formula+' = 100')結果:
/usr/bin/python/268165.html">python3.5 /home/kang/workspace/Qt3d/test.py123+45-67+8-9 = 100123+4-5+67-89 = 100123-45-67+89 = 100123-4-5-6-7+8-9 = 10012+3+4+5-6-7+89 = 10012+3-4+5+67+8+9 = 10012-3-4+5-6+7+89 = 1001+23-4+56+7+8+9 = 1001+23-4+5+6+78-9 = 1001+2+34-5+67-8+9 = 1001+2+3-4+5+6+78+9 = 100
下面再看一個小實例:
題目:輸入三個整數x,y,z,請把這三個數由小到大輸出。
程序分析:我們想辦法把最小的數放到x上,先將x與y進行比較,如果x>y則將x與y的值進行交換,然后再用x與z進行比較,如果x>z則將x與z的值進行交換,這樣能使x最小。
程序源代碼:
#!/usr/bin/python# -*- coding: UTF-8 -*- l = []for i in range(3): x = int(raw_input('integer:/n')) l.append(x)l.sort()print l以上實例輸出結果為:
integer:8integer:5integer:6[5, 6, 8]
總結
以上就是小編分享給大家的有關Python的實例,希望對大家有所幫助。有什么問題可以隨時留言,小編會及時回復大家的。
新聞熱點
疑難解答