题目描述
将一个正整数N分解成几个正整数相加,可以有多种分解方法,例如7=6+1,7=5+2,7=5+1+1,…。编程求出正整数N的所有整数分解式子。
输入格式
每个输入包含一个测试用例,即正整数N (0<N≤30)。
输出格式![输出格式](https://img-blog.csdnimg.cn/20200226170138657.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80NDIyMzM0NQ==,size_16,color_FFFFFF,t_70)
输入样例
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;7=7
基本思路
用到了回溯的思想,主要内容为dfs()函数,用到两个参数num和step。
-
num表示在此之前step-1个数总和。
-
step表示准备查找的第step个数。
对于dfs函数部分注
- 满足条件:即当num等于总数n时。
- 什么时候输出分号:如果当前输出的组数sum为5,9,13时不需要输出,其他时候输出。
- 打印:首先输出“7=1”,再输出“+1”,“+1”……
- 换行:如果当前输出的组数sum 为4的倍数时,并且在该组打印之后换行
- 边界:当num大于n时,退出
- 循环:从1 到 n ,需要满足a[i]>a[i-1] 满足题目递增的要求
#include <iostream>
#include <iomanip>
#include "string"
//#include "math.h"
#include <cstdlib>
#include<algorithm>//排序sort()
using namespace std;
int n;
int sum=1;// 接下来的是第几组
int a[50]={0};
void dfs(int num,int step) //
{ //step表示当前第几个数
//num表示当前相加的和
if(num == n)
{
if(sum % 4 != 1) cout<<";"; //如果后面是第5,9组就不输出';'
cout << num << "=" << a[1];
for(int i = 2; i < step; i++)
cout << "+" << a[i];
if(sum % 4 == 0 && sum!=0) cout<<endl;
sum++;
}
if(num > n) return;
for (int i = 1; i <= n; ++i) {
a[step]=i;
if(a[step] >= a[step - 1])
dfs(num+i,step+1);
}
}
int main()
{
cin>>n;
dfs(0,1);
return 0;
}