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;
}
相关推荐
躲着人群9 分钟前
马拉车(Manacher)算法
c语言·数据结构·c++·算法
tanyongxi6616 分钟前
从零手写红黑树(C++实现详解)
开发语言·数据结构·c++·算法
一只小蒟蒻32 分钟前
搜索 #1 DFS讲解
算法·深度优先
NuyoahC1 小时前
HOT100——排序篇Leetcode215. 数组中的第K个最大元素
c++·leetcode·排序算法·排序
chenjazz1 小时前
算法基础知识总结
数据结构·算法·排序算法
秋风战士1 小时前
通信算法之294:LTE系统中的整数倍频偏估计
人工智能·python·算法
zaiyang遇见1 小时前
P1205 [USACO1.2] 方块转换 Transformations
数据结构·算法·模拟·信息学奥赛·程序设计竞赛·usaco·完全搜索
理论最高的吻1 小时前
最终分配算法【论文材料】
算法
冷月葬花~1 小时前
day25 力扣90.子集II 力扣46.全排列 力扣47.全排列 II
数据结构·算法·leetcode
nako_sayuri1 小时前
可获得的最大点数
算法