#include
int found(int a[][30],int n)
{
int row=0,col=0,presum=0;
int i,j;
for(i=1;i<=n;i++)
{
for(j=i;j<=n;j++)
{
presum+=j;
if(presum<=n)
{
a[row][col]=j;
col++;
}
if(presum==n)
{
row++;
break;
}
if(presum>n)
break;
}
presum=0;
col=0;
}
for(i=0;i<=row;i++)
{
for(j=0;j<30;j++)
if(a[i][j]!=0)
printf("%d ",a[i][j]);
printf("\n");
}
return row;
}
int main()
{
int a[20][30]={0},i,j;
int n;
for(i=0;i<20;i++)
for(j=0;j<30;j++)
a[i][j]=0;
scanf("%d",&n);
i=found(a,n);
return 0;
}
例如輸入:500
輸出:
8 9 10 11 12 13 14 15....32
59 60 61 ...66
98 99 100 101 102
500
為什麼我的代碼達不到,我想要的效果!求大神指錯啊!
這個問題我回答過,自己去看吧
http://ask.csdn.net/questions/162483