-2

これは、次のルールを持つ非常に単純なサイコロ ゲームです。

  1. 1 から 100 までの数字を選択してください
  2. 一度に3つのサイコロを振る
  3. ロールされたポイントと次のオプションを使用して、選択した数にできるだけ近づきます。

    • 加算、減算、乗算および/または
    • ポイントを10倍する

例 1:

Dice1 = 2, Dice2 = 3, Dice3 = 1, Chosen number = 5

Possible calculations:           
         2 + 3 * 1 = 5 or 
         2 * 3 - 1 = 5

例 2:

Dice1 = 6, Dice2 = 2, Dice3 = 2, Chosen number = 42

Possible calculation:
         (6*10) - (2*10) + 2 = 42

私のプログラムの目標は、点と演算子を組み合わせる最良の方法を見つけることです。

私がこれまでに持っているもの:

import sys
import operator

a = int (sys.argv[1])   # Dice 1
b = int (sys.argv[2])   # Dice 2
c = int (sys.argv[3])   # Dice 3
d = int (sys.argv[4])   # Number to reach

class Calc():

    def __init__(self):
        self.resultsdict = dict()
        self.werte = dict()
        permutations = [[a,b,c], [a,c,b], [b,a,c], [b,c,a], [c,a,b], [c,b,a]]
        for p in permutations:
            aa = int(p[0])
            bb = int(p[1])
            cc = int(p[2])
            self.compute(aa,bb,cc, d)
        self.getBest(d, a, b, c)

    def compute(self, a,b,c,d):
        func = [a+b+c, a+b-c, a+b*c, (a+b)*c, (a-b)+c, a-(b+c), a-b-c, a-b*c, (a-b)*c, a*b+c, a*(b+c), a*b-c, a*(b-c), a*b*c]
        func1 = ["a+b+c", "a+b-c", "a+b*c", "(a+b)*c", "(a-b)+c", "a-(b+c)", "a-b-c", "a-b*c", "(a-b)*c", "a*b+c", "a*(b+c)", "a*b-c", "a*(b-c)", "a*b*c"]
        i = 0
        while i < len(func):
            dictkey = str(a)+str(b)+str(c)+ ", " +str(func1[i])
            if  not func[i] < 0 :
                self.resultsdict[dictkey] = abs(d-func[i])
                self.werte[dictkey] = func[i]
            i += 1

    def getBest(self, d, d1, d2, d3):
        self.bestresults = dict()
        keys = self.resultsdict.keys()
        minval = 1000000000
        for k in keys:
            if int(self.resultsdict[k]) <= int(minval):
                minval = int(self.resultsdict[k])
        print("THE BEST COMBINATION FOR REACHING " + str(d) + " WITH " + str(d1) + ", " + str(d2) + ", " + str(d3) + " HAS BEEN GAINED WITH REST: " + str(minval)) 
        for k in keys:
            if int(self.resultsdict[k]) == int(minval):
                ergebnis = self.werte[k]
                print('\t' + "Combination: " + str(k) + ", Result: " + str(ergebnis))   
t = Calc()

func では、可能な組み合わせの一部をハードコーディングしました。

今、これらの組み合わせを自動的に生成するアルゴリズムを探しているので、それらをすべて手動で書き留める必要はありません。

どうやってそれをしますか?

4

1 に答える 1