zhshuhf.cpp

来自「整数划分问题: 对于正整数n」· C++ 代码 · 共 65 行

CPP
65
字号
#include "stdio.h" 

void main() 
{ 
int n; 
scanf("%d", &n); 

if (n == 1) 
{ 
printf("1=1\n"); 
return; 
} 

if (n == 2) 
{ 
printf("2=1+1\n"); 
return; 
} 

int *a = new int(n); 
int top = 0; 
a[0] = n - 1; 
a[1] = 1; 
top = 2; 

int i; 
do{ 
printf("%d=%d", n, a[0]); 
for (i = 1; i < top; i++) 
{ 
printf("+%d", a[i]); 
} 
printf("\n"); 

int s = 0; 
do{ 
s += a[--top]; 
}while (top >= 0 && a[top] == 1); 
if (top == -1) 
{ 
break; 
} 

int d = a[top] - 1; 
if (d == 1) 
{ 
while (s > 0) 
{ 
a[top++] = 1; 
s--; 
} 
} 
else 
{ 
do{ 
a[top++] = d; 
s -= d; 
}while (s >= d); 
if (s != 0) 
{ 
a[top++] = s; 
} 
} 
}while (1); 
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?