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整个程序结束!

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

相关推荐
JieE21214 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050733 天前
(一)小红的数组操作
算法·编程语言