C++题解(37) 信息学奥赛一本通1318:【例5.3】自然数的拆分

时间限制: 1000 ms 内存限制: 65536 KB

提交数:48820 通过数: 28647

【题目描述】

任何一个大于1的自然数n,总可以拆分成若干个小于n的自然数之和。

当n=7共14种拆分方法:

复制代码
7=1+1+1+1+1+1+1
7=1+1+1+1+1+2
7=1+1+1+1+3
7=1+1+1+2+2
7=1+1+1+4
7=1+1+2+3
7=1+1+5
7=1+2+2+2
7=1+2+4
7=1+3+3
7=1+6
7=2+2+3
7=2+5
7=3+4
total=14

【输入】

输入n。

【输出】

按字典序输出具体的方案。

【输入样例】

复制代码
7

【输出样例】

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

参考答案

复制代码
#include<bits/stdc++.h>
using namespace std;
int n, a[10001], ai; 

void show()
{
    cout << n << "=";
    cout << a[1];
    for(int i = 2; i <= ai; ++i)
        cout << '+' << a[i];
    cout << endl;
}

void dfs(int m, int st)
{
    for(int i = st; i <= m && i < n; ++i) 
    {
        a[++ai] = i;
        if(m - i == 0) 
            show();
        else if(m - i > 0)
            dfs(m - i, i);
        ai--;
    }
}

int main()
{
    cin >> n;
    dfs(n, 1);
    return 0;
}
相关推荐
qq_4335545412 小时前
C++ manacher(求解回文串问题)
开发语言·c++·算法
歌_顿12 小时前
知识蒸馏学习总结
人工智能·算法
闲看云起13 小时前
LeetCode-day6:接雨水
算法·leetcode·职场和发展
没学上了13 小时前
VLM_一维离散卷积与二维离散卷积(还是复习感觉还行)
算法
HL_风神13 小时前
设计原则之迪米特
c++·学习·设计模式
黛色正浓13 小时前
leetCode-热题100-贪心合集(JavaScript)
javascript·算法·leetcode
HL_风神13 小时前
设计原则之合成复用
c++·学习·设计模式
轻微的风格艾丝凡14 小时前
嵌入式定时器计时技巧:用有符号数省略溢出判断的底层逻辑与实践
数据库·算法·dsp开发·嵌入式软件
No0d1es14 小时前
2025年12月 GESP CCF编程能力等级认证C++四级真题
算法·青少年编程·等级考试·gesp·ccf
汉克老师14 小时前
GESP2025年12月认证C++八级真题与解析(单选题10-12)
c++·递归··gesp八级·gesp8级