洛谷 P2404 自然数的拆分问题

题目链接

https://www.luogu.org/problemnew/show/P2404


题目背景

木有......


题目描述

任何一个大于1的自然数n,总可以拆分成若干个小于n的自然数之和。现在给你一个自然数n,要求你求出n的拆分成一些数字的和。每个拆分后的序列中的数字从小到大排序。然后你需要输出这些序列,其中字典序小的序列需要优先输出。


输入输出格式

输入格式:

输入:待拆分的自然数n。

输出格式:

输出:若干数的加法式子。


思路

用搜索和回溯做吧......比那个输出素数环还要简单的啦
这道题属于回溯的一道板子题,还是比较好做的
可以一路搜到底得到一种方案,然后在这次的方案排列完毕后,回溯,继续搜索下一方案


代码

#include<bits/stdc++.h>
using namespace std;

int a[10086]= {1};
int n,total;
int search(int,int);
int print(int);

int main() {
    scanf("%d",&n);
    search(n,1);
    return 0;
}

int search(int s,int t) {
    for(int i=a[t-1]; i<=s; i++) {
        if(i<n) {
            a[t]=i;
            s-=i;
            if(s==0)print(t);
            else search(s,t+1);
            s+=i;
        }
    }
}

int print(int t) {
    for(int i=1; i<=t-1; i++) {
        cout<<a[i]<<"+";
    }
    cout<<a[t]<<endl;
}
全部评论

相关推荐

03-03 23:12
已编辑
北京邮电大学 Java
书海为家:我来给一点点小建议,因为毕竟还在学校不像工作几年的老鸟有丰富的项目经验,面试官在面试在校生的时候更关注咱们同学的做事逻辑和思路,所以最好在简历中描述下自己做过项目的完整过程,比如需求怎么来的,你对需求的解读,你想到的解决办法,遇到困难如何找人求助,最终项目做成了什么程度,你从中收获了哪些技能,你有什么感悟。
你的简历改到第几版了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务