洛谷(DFS)-P2089 烤鸡详解

提前说一下,做完才发现要先输出方案数而后才打印方案数,所以代码不能直接搬动提交,你可以建立个字符串存储一下.

先上代码,看不懂的再看下面的详解:

cpp 复制代码
#include<iostream>
#include <bits/stdc++.h>
using namespace std;
const int N = 20;
int n;
int ac[N];//方案存储
int res = 0;//方案数
//深度搜索
void dfs(int x, int sum) {//行状态 与 调料总和
    if (sum > n) return; // 调料总和 超过限制
    if (x > 10) {//第11种调料的时候开始检测方案
        if (sum == n) {//方案成立
            res++;//方案数+1
            for (int i = 1; i <= 10; ++i) {
                cout << ac[i];//格式化输出
                if (i != 10) cout << " ";
            }cout << endl;
        }
        return;//强制这个方案结束
    }
    for (int i = 1; i <= 3; ++i) {//深搜调料
        ac[x] = i;//放入调料
        dfs(x + 1, sum + i);//继续匹配
        ac[x] = 0;//回溯
    }
}
int main()
{
    cin >> n;
    dfs(1, 0);
    cout << res << endl;
    return 0;
}

详解:

Main部分,不必多说,自然是按题目输入一个数N,而后使它进入DFS函数内开始获得答案.

其中,dfs的初始值1是抽象概念,因为我是从第一处放调料而不是第0处,初始值0则是已放的调料总数,观察题目可知它是每种可以放1-3个的,这关系到后面的DFS内for循环的范围.

DFS部分:

我们需要在放调料之前,查看调料的总和是否超过N(美味程度)如果超过了 方案作废了 return

而后查找X是否为11 在11的时候判断前10项之和-Sum是否达到了预期,是则方案数+1,你也需要在这里开始准备打印的字符串为输出做好准备.

注意,在x>10后面嵌套的if sum==n结束时有一个强制return , 如果没有它,那么你的题目必然会出错,因为没有return意味着后面它还会继续放...所以你必须强制停止它.

核心内容:for循环,它的范围是1-3对应着题目所要求的可以放1-3量的料,而后将结果传入dfs中,它下面的回溯是非必要的,注意.

相关推荐
电鱼智能的电小鱼11 小时前
基于电鱼 AI 工控机的智慧工地视频智能分析方案——边缘端AI检测,实现无人值守下的实时安全预警
网络·人工智能·嵌入式硬件·算法·安全·音视频
孫治AllenSun12 小时前
【算法】图相关算法和递归
windows·python·算法
格图素书13 小时前
数学建模算法案例精讲500篇-【数学建模】DBSCAN聚类算法
算法·数据挖掘·聚类
DashVector14 小时前
向量检索服务 DashVector产品计费
数据库·数据仓库·人工智能·算法·向量检索
AI纪元故事会14 小时前
【计算机视觉目标检测算法对比:R-CNN、YOLO与SSD全面解析】
人工智能·算法·目标检测·计算机视觉
夏鹏今天学习了吗14 小时前
【LeetCode热题100(59/100)】分割回文串
算法·leetcode·深度优先
卡提西亚14 小时前
C++笔记-10-循环语句
c++·笔记·算法
还是码字踏实14 小时前
基础数据结构之数组的双指针技巧之对撞指针(两端向中间):三数之和(LeetCode 15 中等题)
数据结构·算法·leetcode·双指针·对撞指针
Coovally AI模型快速验证16 小时前
当视觉语言模型接收到相互矛盾的信息时,它会相信哪个信号?
人工智能·深度学习·算法·机器学习·目标跟踪·语言模型
电院工程师16 小时前
SIMON64/128算法Verilog流水线实现(附Python实现)
python·嵌入式硬件·算法·密码学