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

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

相关推荐
逻辑驱动的ken43 分钟前
Java高频面试考点场景题09
java·开发语言·数据库·算法·oracle·哈希算法·散列表
帅小伙―苏1 小时前
力扣42接雨水
前端·算法·leetcode
AI科技星1 小时前
精细结构常数α的几何本源:从第一性原理的求导证明、量纲分析与全域验证
算法·机器学习·数学建模·数据挖掘·量子计算
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 287. 寻找重复数 | C++ 数组判环 (快慢指针终极解法)
c++·算法·leetcode
MegaDataFlowers1 小时前
26.删除有序数组中的重复项
算法
故事和你913 小时前
洛谷-数据结构1-4-图的基本应用2
开发语言·数据结构·算法·深度优先·动态规划·图论
吴可可1233 小时前
C#合并首尾相连多段线实战
算法·c#
KMDxiaozuanfeng3 小时前
卡梅德生物技术快报|SPR 技术应用|基于 SPR 亲和力的中药活性成分筛选系统实现与数据分析
科技·算法·面试·考试
꧁细听勿语情꧂4 小时前
数据结构概念和算法、时间复杂度、空间复杂度引入
c语言·开发语言·数据结构·算法
Felven4 小时前
B. The 67th 6-7 Integer Problem
数据结构·算法