iPad遊戲 Calcculator: The Game 程序自動計算求解方法

今天在iPad上下了個小遊戲,主要是一個計算器的界面,有開始值,目標值,限定步數,以及一些加減乘除,還有做者腦洞想出來的功能鍵,主要有左移,直接把一個數加到末尾,將其中的某個數改成另外一個數等等。。玩到20幾關的時候感受每道題要想一下子才能解出來,因而有了下面的程序,寫完程序就不想玩了。java

遊戲界面以下,就像一個真的計算器。其中紫色的二、5分別表示在當前數字最後插入二、5,+5和-5就是加減,初始值是0,限定5步,獲得目標值210,想一想該怎麼操做?是否是不是太容易一眼看出來?這就對了,這麼容易讓你看出來做者怎麼賺錢?ide

答案是:SET 2==>2, SET 5==>25, SUB 5 ==> 20, SET 5 ==>205, ADD 5 ==> 210this

 

代碼以下,用回溯的思想,DFS實現的。google

package com;

import com.google.common.collect.Lists;

import java.util.ArrayDeque;
import java.util.Deque;
import java.util.List;

/**
 * 2018-08-24 下午10:36.
 *
 */
public class Calc {
    public static void main(String[] args) {
        int n = 5;
        int start = 0;
        int target = 210;
        List<Num> list = Lists.newArrayList();
        list.add(new Num(OpType.SET, 2));
        list.add(new Num(OpType.SET, 5));
//        list.add(new Num(OpType.LEFT_SHIFT, 0));
        list.add(new Num(OpType.ADD, 5));
        list.add(new Num(OpType.SUB, 5));
//        list.add(new Num(OpType.SET, 0));
//        list.add(new Num(OpType.SET, 5));
        dfs(list, new ArrayDeque<>(), n, start, target);
    }

    static void dfs(List<Num> list, Deque<Num> res, int step, int last, int target) {
        if (list == null || list.size() == 0 || step <= 0) {
            return;
        }
        for (int i = 0; i < list.size(); i++) {
            Num num = list.get(i);
            int tmp = num.calc(last);
            if (tmp == 0xdeadbeef) {
                continue;
            }
            res.offer(num);
            if (tmp == target) {
                System.out.println(res);
            } else {
                dfs(list, res, step - 1, tmp, target);
            }
            res.pollLast();
        }
    }

    static class Num {
        OpType opType;
        int num;

        protected Num(OpType opType, int num) {
            this.opType = opType;
            this.num = num;
        }

        public int calc(int last) {
            if (this.opType == OpType.SET) {
                if (last == 0) {
                    return this.num;
                } else {
                    return last * (int)Math.pow(10, this.num / 10 + 1) + this.num;
                }
            }
            if (this.opType == OpType.LEFT_SHIFT) {
                return last / 10;
            }
            if (this.opType == OpType.ADD) {
                return this.num + last;
            }
            if (this.opType == OpType.SUB) {
                return last - this.num;
            }
            if (this.opType == OpType.MUL) {
                return last * this.num;
            } else {
                if (last % this.num == 0) {
                    return last / this.num;
                } else {
                    return 0xdeadbeef;
                }
            }
        }

        @Override
        public String toString() {
            return "Num{" +
                    "opType=" + opType +
                    ", num=" + num +
                    '}';
        }
    }

    enum OpType {
        SET, ADD, SUB, MUL, DIV, LEFT_SHIFT;
    }
}

上面那道題代碼輸出就是:spa

[Num{opType=SET, num=2}, Num{opType=SET, num=5}, Num{opType=SUB, num=5}, Num{opType=SET, num=5}, Num{opType=ADD, num=5}]code

根據輸出操做便可。blog

目前定義了幾個基本操做,固然估計這遊戲後面估計還有其餘的神奇操做,我沒有繼續日後玩了就寫到這裏了。遊戲

相關文章
相關標籤/搜索