【洛谷题解】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后输出

相关推荐
sprintzer15 小时前
1.6-1.15力扣数学刷题
算法·leetcode·职场和发展
jiang_bluetooth15 小时前
channel sounding基于探测序列的时延和相位差算法
算法·蓝牙测距·channel sound·gfsk·蓝牙6.0
地平线开发者16 小时前
征程 6 算法工具链 | PTQ 深度使用指南
算法·自动驾驶
Xの哲學16 小时前
Linux 软中断深度剖析: 从设计思想到实战调试
linux·网络·算法·架构·边缘计算
暴风游侠16 小时前
如何进行科学的分类
笔记·算法·分类
leaves falling16 小时前
冒泡排序(基础版+通用版)
数据结构·算法·排序算法
C雨后彩虹17 小时前
无向图染色
java·数据结构·算法·华为·面试
坚持就完事了17 小时前
扫描线算法
算法
鱼跃鹰飞17 小时前
Leetcode尊享面试100题:252. 会议室
算法·leetcode·面试
程序员-King.17 小时前
二分查找——算法总结与教学指南
数据结构·算法