C語言遞歸在實踐題目中應用詳解_第1頁
C語言遞歸在實踐題目中應用詳解_第2頁
C語言遞歸在實踐題目中應用詳解_第3頁
C語言遞歸在實踐題目中應用詳解_第4頁
C語言遞歸在實踐題目中應用詳解_第5頁
已閱讀5頁,還剩2頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

第C語言遞歸在實踐題目中應用詳解目錄遞歸知識點題目第一題第二題第三題第四題第五題第六題第七題

遞歸知識點

遞歸概念:程序調用自身的編程技巧稱為遞歸(recursion)。遞歸做為一種算法在程序設計語言中廣泛應用。一個過程或函數在其定義或說明中有直接或間接調用自身的一種方法,它通常把一個大型復雜的問題層層轉化為一個與原問題相似的規(guī)模較小的問題來求解,遞歸策略只需少量的程序就可描述出解題過程所需要的多次重復計算,大大地減少了程序的代碼量。

通俗理解就是:函數自己調用自己

遞歸的主要思考方式就是大事化小

遞歸的兩個必要條件

1.存在限制條件,當滿足這個限制條件的時候,遞歸便不再繼續(xù)

2.每次遞歸調用之后越來越接近這個限制條件

(滿足以上必要條件的不一定是遞歸,但不滿足條件的一定不是遞歸)

題目

第一題

接收一個整型數值,按照順序打印它的每一位

輸入:1234輸出:1234

來看看函數內部:

#includestdio.h

voidprint(intn)

if(n9)

print(n/10);

printf("%d",n%10);

intmain()

intn=0;

scanf("%d",

print(n);

return0;

}

第二題

求n的階乘

進入函數內部:

#includestdio.h

intfactorial(intn)

if(n=1)

return1;

else

returnn*factorial(n-1);

intmain()

intn=0;

scanf("%d",

intret=factorial(n);

printf("%d\n",ret);

return0;

}

第三題

用遞歸的方法求字符串長度

#includestdio.h

intmy_strlen(char*str)

if(*str=='\0')

return0;

else

return1+my_strlen(str+1);

intmain()

chararr[]="hello";

intret=my_strlen(arr);

printf("%d\n",ret);

return0;

}

第四題

用遞歸求第n個斐波那契數(不考慮溢出)

進入函數內部:

#includestdio.h

intFib(intn)

if(n=2)

return1;

else

returnFib(n-1)+Fib(n-2);

intmain()

intn=0;

scanf("%d",

intret=Fib(n);

printf("%d\n",ret);

return0;

}

第五題

進入函數內部:

#includestdio.h

intDig(intn)

if(n9)

returnDig(n/10)+n%10;

else

returnn;

intmain()

intn=0;

scanf("%d",

intret=Dig(n);

printf("%d\n",ret);

return0;

}

第六題

用遞歸實現(xiàn)n的k次方

進入函數內部:

#includestdio.h

doublePow(intn,intk)

if(k0)

returnn*Pow(n,k-1);

elseif(k==0)

return1;

else

return1.0/Pow(n,-k);

intmain()

intn=0;

intk=0;

scanf("%d%d",n,

doubleret=Pow(n,k);

printf("%lf\n",ret);

return0;

}

第七題

小樂樂上課需要走n階臺階,

所以每次可以選擇走一階或者走兩階,那么他一共有多少種走法?

進入函數內部:

#includestdio.h

intjump(intn)

if(n=2)

returnn;

else

returnjump(n-1)+ju

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論