P674 三羊献瑞

这道题需要用到dfs

我们看代码

java 复制代码
import java.util.*;

public class Main {
    static boolean found = false;
    public static void main(String[] args) {
        int[] arr = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
        dfs(arr,0);
    }
    public static boolean dfs(int[] x , int k){
        if(found)return true;
        if(k >= 10){
            int a = x[0]*1000 + x[1]*100 + x[2]*10 + x[3];
            int b = x[4]*1000 + x[5]*100 + x[6]*10 + x[1];
            int c = x[4]*10000 + x[5]*1000 + x[2]*100 + x[1]*10 + x[7];
            if(x[0] == 0 || x[4] == 0) return false;
            if(a+b==c){
                System.out.println(b);
                found = true;
                return true;
            }
            return false;
        }
        for(int i = k ; i < x.length ; i++){
            int t = x[i];
            x[i] = x[k];
            x[k] = t;
            if(dfs(x , k+1)){
                return true;
            }
             t = x[i];
            x[i] = x[k];
            x[k] = t;
        }
        return false;
    }
}

我们分步来看

一,

这一部分先是定义了一个全局变量found

dfs递归k = 0是为了从0开始填补,不明白我们接着往下看

二,

复制代码
if(found)return true;如果结果已找到,直接返回

当k>=10的时候,说明数字已经全部填补完整

首位数字不能为0

当找到方案的时候,输出b并结束

没找到就向上返回

三,

这是递归的关键代码

这是让k从0开始

一次一次的尝试,如果再次向下走的时候成功找到方案,就向上返回

假如k=10 找到答案 → return true → 传给 k=9 k=9 收到 true → 也 return true→ 传给 k=8 k=8 收到 true → 也 return true→ 一直传到 k=0 → 最后回到 main整个程序结束!

后面是进行回溯,没找到就要换路,换路的时候要回溯到上个状态

相关推荐
发疯幼稚鬼3 小时前
大整数乘法运算
c语言·算法
宵时待雨3 小时前
C++笔记归纳17:哈希
数据结构·c++·笔记·算法·哈希算法
问好眼3 小时前
《算法竞赛进阶指南》0x05 排序-1.电影
c++·算法·排序·信息学奥赛
CoderCodingNo3 小时前
【GESP】C++八级考试大纲知识点梳理 (6) 图论算法:最小生成树与最短路
c++·算法·图论
DeepModel3 小时前
【特征选择】嵌入法(Embedded)
人工智能·python·深度学习·算法
今儿敲了吗4 小时前
算法复盘——前缀和
笔记·学习·算法
ulias2124 小时前
智能指针简述
开发语言·c++·算法
寻寻觅觅☆4 小时前
东华OJ-基础题-58-素数表(C++)
开发语言·c++·算法
AI成长日志4 小时前
【强化学习专栏】深度拆解:多智能体强化学习核心理论与工程实践
算法