题解 | #24点游戏算法#

24点游戏算法

http://www.nowcoder.com/practice/fbc417f314f745b1978fc751a54ac8cb


import java.util.Scanner;

public class Main {
    private static int isSolve = 0;
    public static void dfs(int index,int currentNum,int[] arr){
        if(currentNum == 24){
            isSolve = 1;
            return;// 结束递归
        }
        if(isSolve == 1 || currentNum > 24 || index >= 4)
        {
                return ;
        }
        for(int i = 0; i < 4;i++){
            switch (i){
                case 0:
                    dfs(index+1,currentNum - arr[index],arr);
                    break;
                case 1:
                    dfs(index+1,currentNum + arr[index],arr);
                    break;
                case 2:
                    dfs(index+1,currentNum * arr[index],arr);
                    break;
                case 3:
                    dfs(index+1,currentNum / arr[index],arr);
                    break;
            }
            if(isSolve == 1) return;
        }

    }
    public static void getAllOrder(int[] array,int start,int end){
        // 获得全排序
        if(start == end){
            // 调用dfs方法
            dfs(1,array[0],array);
            return;
        }else{
            for(int i = start;i < end;i++){
                swap(array,start,i);// 交换
                getAllOrder(array,start + 1,end);// 找出1 - n-1个数的全排列
                swap(array,i,start);
            }
        }
    }
    // 交换两个元素的位置
    private static  void swap(int[] array,int i,int j){
        if(i == j){

            return;
        }
        int temp = temp = array[i];
        array[i] = array[j];
        array[j] = temp;
    }
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        while(sc.hasNextInt()){
            int[] num = new int[4];
            for(int i = 0 ; i <= 3; i++)
                num[i] = sc.nextInt();
//            String temp = sc.nextLine();
            // 调用的数据要有一个全排列,这样才能保证全部情况都出现了,否则有可能漏掉
            getAllOrder(num,0,4);
            System.out.println(isSolve == 1 ? true : false +"");
//            System.out.println((flag == true ? true :false) +"");
        }

    }
}

全部评论

相关推荐

找个工作&nbsp;学历是要卡的&nbsp;要求是高的&nbsp;技能不足是真的&nbsp;实习经验是0的&nbsp;简历无处可写是事实的&nbsp;钱不好赚是真的&nbsp;想躺平又不敢躺&nbsp;也不甘心躺&nbsp;怕自己的灵感和才华被掩埋甚至从未被自己发现&nbsp;又质疑自己是否真正有才华
码农索隆:你现在啊,你心里都明白咋回事,但是你没办法改变现状,一想到未来,你又没有信心狠下心来在当下努力。 得走出这种状态,不能一直困在那里面,哪不行就去提升哪,你一动不动那指定改变不了未来,动起来,积少成多才能越来越好
点赞 评论 收藏
分享
07-02 13:52
武汉大学 golang
骗你的不露头也秒
牛客87776816...:😃查看图片
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务