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;
}
相关推荐
小糖学代码17 小时前
Linux:11.线程概念与控制
linux·服务器·c语言·开发语言·c++
科研小白_18 小时前
基于遗传算法优化BP神经网络(GA-BP)的数据时序预测
人工智能·算法·回归
Terry Cao 漕河泾18 小时前
基于dtw算法的动作、动态识别
算法
Larry_Yanan20 小时前
QML学习笔记(四十)QML的ApplicationWindow和StackView
c++·笔记·qt·学习·ui
Miraitowa_cheems21 小时前
LeetCode算法日记 - Day 73: 最小路径和、地下城游戏
数据结构·算法·leetcode·职场和发展·深度优先·动态规划·推荐算法
野蛮人6号21 小时前
力扣热题100道之560和位K的子数组
数据结构·算法·leetcode
Swift社区1 天前
LeetCode 400 - 第 N 位数字
算法·leetcode·职场和发展
fengfuyao9851 天前
BCH码编译码仿真与误码率性能分析
算法
Kratzdisteln1 天前
【C语言】Dev-C++如何编译C语言程序?从安装到运行一步到位
c语言·c++
小白不想白a1 天前
每日手撕算法--哈希映射/链表存储数求和
数据结构·算法