【洛谷题解】P2404 自然数的拆分问题

题目链接:自然数的拆分问题 - 洛谷

题目难度:普及-

涉及知识点:深搜剪枝

题意:

输入样例:7

输出样例:

复制代码
1+1+1+1+1+1+1
1+1+1+1+1+2
1+1+1+1+3
1+1+1+2+2
1+1+1+4
1+1+2+3
1+1+5
1+2+2+2
1+2+4
1+3+3
1+6
2+2+3
2+5
3+4

分析:从a开始减,减到0后输出

AC代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int a,b[50]={1};//初始化b数组
void print(int c)
{
    for(int i=1; i<c; i++)//最后一个元素特殊处理
        cout<<b[i]<<"+";
    cout<<b[c]<<endl;//输出换行
}
void dfs(int c)
{
    for(int i=b[c-1]; i<=a; i++)//剪枝优化,搜过的不再搜
    {
        b[c]=i;//c作统计几个部分
        a-=i;//a减去i
        if(a==0&&c!=1) print(c);//当a被减完后输出,并特殊处理c==1,不输出
        else dfs(c+1);//搜索下一层
        a+=i;//回溯
    }
}
int main()
{
    ios::sync_with_stdio(false);//加快cin,cout
    cin>>a;
    dfs(1);//从一个部分开始
    return 0;
}

总结:从a开始减,减到0后输出

相关推荐
xlq2232235 分钟前
22.多态(上)
开发语言·c++·算法
666HZ66637 分钟前
C语言——高精度加法
c语言·开发语言·算法
sweet丶44 分钟前
iOS MMKV原理整理总结:比UserDefaults快100倍的存储方案是如何炼成的?
算法·架构
云里雾里!2 小时前
力扣 209. 长度最小的子数组:滑动窗口解法完整解析
数据结构·算法·leetcode
CoderYanger3 小时前
递归、搜索与回溯-穷举vs暴搜vs深搜vs回溯vs剪枝:12.全排列
java·算法·leetcode·机器学习·深度优先·剪枝·1024程序员节
憨憨崽&3 小时前
进击大厂:程序员必须修炼的算法“内功”与思维体系
开发语言·数据结构·算法·链表·贪心算法·线性回归·动态规划
chem41114 小时前
C 语言 函数指针和函数指针数组
c语言·数据结构·算法
liu****4 小时前
八.函数递归
c语言·开发语言·数据结构·c++·算法
客梦4 小时前
数据结构-树结构
数据结构·笔记
CM莫问4 小时前
详解机器学习经典模型(原理及应用)——岭回归
人工智能·python·算法·机器学习·回归