最怕带for循环的递归函数
											整数分解问题
1=1;
3=1+1+1;3=1+2;3=3;
这个程序我是画了程序运行情况的图才知道为什么search(remainder-i,i,nTerm+1)而不是search(remainder-i,i,nTerm++)
像归并排序这种递归,我现在也不思考程序如何运行了,假设递归是对的,直接往下写。
可如果是这种带for循环的我就头疼了,有人能解释下那个for(){ 递归函数 } 么
 程序代码:
程序代码:#include <stdio.h>
#define MaxN 30
int Terms[MaxN] ;
int N ;
int count ;
void Search( int remainder , int start , int nTerm )
{
    int i;
    if( remainder==0 ) 
    {
        count++ ;    //记录当前结果数,方便输出符号
        if( count%4 != 1 )
            printf(";") ;
        printf( "%d=%d",N,Terms[0] ) ;
        for(i=1 ; i<nTerm ;i++)
            printf( "+%d" , Terms[i] ) ;
        if (count%4==0)
            printf("\n") ;        
    }
    else
    for( i=start ; i<=remainder ; i++ )
    {        
        Terms[nTerm] = i ;
        Search( remainder-i , i , nTerm+1 ) ;        
    }
}
int main()
{
    scanf("%d" , &N) ;
    
    count = 0 ;
    Search(N , 1 , 0) ;
    if(count%4!= 0)
        printf("\n") ;
    return 0 ;
}										
					
	
 
											






 
	    




 
										
					
	 
											