⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 zhshuhf.cpp

📁 整数划分问题: 对于正整数n
💻 CPP
字号:
#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 + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -