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

相关推荐
Moonbit20 分钟前
月报Vol.03: 新增Bitstring pattern支持,构造器模式匹配增强
后端·算法·github
快手技术24 分钟前
多模态大模型Keye-VL-1.5发布!视频理解能力更强!
算法
薛定谔的算法40 分钟前
JavaScript数组操作完全指南:从基础到高级
前端·javascript·算法
可爱的小小小狼42 分钟前
算法:位运算
算法
zzzsde1 小时前
【数据结构】强化训练:从基础到入门到进阶(1)
数据结构
VisionPowerful1 小时前
九.弗洛伊德(Floyd)算法
算法·c#
可爱的小小小狼1 小时前
算法:哈希表
redis·算法·散列表
奔跑吧 android1 小时前
【linux kernel 常用数据结构和设计模式】【数据结构 3】【模拟input子系统input_dev和input_handler之间的多对多关系】
linux·数据结构·input·kernel·input_dev·input_handler·input_handle
点云侠2 小时前
解决Visual Studio 2022编译工程速度慢的问题
开发语言·c++·ide·算法·计算机视觉·visual studio
THMAIL2 小时前
深度学习从入门到精通 - 迁移学习实战:用预训练模型解决小样本难题
人工智能·python·深度学习·算法·机器学习·迁移学习