int findf( int n ){
成都創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設,三元企業(yè)網(wǎng)站建設,三元品牌網(wǎng)站建設,網(wǎng)站定制,三元網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,三元網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
int a,b,c;
b = n % 2;
c = 0;
if ( n4){
if (b==c){
a=findf( n-1 ) + findf( n-3 );
}
else{
a=findf( n-2 ) + findf( n-4 );
}
return a;
}
else if ( n 0){
return -1;
}
else{
return 1;
}
}
//循環(huán)實現(xiàn)
#includestdio.h
int?main()
{
int?n,?t?=?0;
scanf("%d",?n);
if(n=0)return?0;
else
while(n){
t?=?t?*?10?+?n?%?10;
n?/=?10;
}
printf("%d",?t);
return?0;
}
簡單修改一下就可以變遞歸了。代碼如下
#includestdio.h
int?fanzhuan(int?n,int?t){
t?=?t?*?10?+?n?%?10;
n?/=?10;
if(n0)return?fanzhuan(n,t);
return?t;
}
int?main()
{
int?n,?t?=?0;
scanf("%d",?n);
if(n=0)return?0;
else?t=fanzhuan(n,t);
printf("%d",?t);
return?0;
}
舉一個用遞歸調用函數(shù)求輸入非負整數(shù)的階乘的例子,如下:
//#include?"stdafx.h"http://If?the?vc++6.0,?with?this?line.
#include?"stdio.h"
int?fact(int?n){
if(n==1?||?n==0)?return?1;
else?return?n*fact(n-1);
}
int?main(void){
int?x;
while(1){
printf("Input?x(int?12=x=0)...\nx=");
if(scanf("%d",x),x=0??x=12)//x12時會使結果溢出
break;
printf("Error,redo:?");
}
printf("%d!?=?%d\n",x,fact(x));
return?0;
}
標個記號準備上傳對大神的源碼分析。好了,我分析了上樓大神的代碼實現(xiàn),具體參考他的代碼,分享下。注:可以看看《算法精解》Kyle Loudon著 ?或者《數(shù)據(jù)結構》?主編 安訓國?他們說的堆棧原理。
#include?stdio.h
char*?dg(char*?instr,?char*?outstr,?char*?outstr2)?
{
if?(*instr?==?0)?
{
*outstr?=?0;
return?outstr2;
}
*(outstr?+?1)?=?*instr;
outstr?=?dg(instr?+?1,?outstr?+?2,?outstr2);
/*?下兩句一直不執(zhí)行,直到outstr?=?dg(instr?+?5,?outstr?+?10,?outstr2)返回后才執(zhí)行,其后不斷執(zhí)行后三句!*/
*outstr?=?*instr?-?32;
return?outstr?+?2;
}
int?main()
{
char?buf[50];
dg("aybdx",?buf,?buf);
puts(buf);
return?0;
}