遞歸函數,也就是不斷的調用自身的函數,使用遞歸能夠比較方便的解決一些比較難使用循環解決的問題。就在這個例子中,求一個數組a[]的前n項和,也就是求a[n-1]+a[n-2]+…+a[0],那么如果一個函數sum是用來求數組前n項和的,sum定義為sum(int a[],int n),則使用遞歸的方式就是
a[n-1]+sum(a,n-1)。
使用代碼來表述可能更好一些:
~~~
#include <stdio.h>
int sum(int test[],int n);
/**
* @brief main 使用遞歸求一個數組的前n個元素的和
* 假設數組為a[];則求其前n的元素的和也就是求
* a[n-1]+a[n-2]+...a[0]
* @return
*/
int main(void)
{
int n;
printf("Please input the number of an array:\n");
scanf("%d",&n);
printf("Please enter the element of the array:\n");
int test[n];
int i;
for(i = 0;i < n;i++)
scanf("%d",&test[i]);
int count = sum(test,n);
printf("The sum of the array is : %d.\n",count);
return 0;
}
/**
* @brief sum 實現前n個元素的和
* @param test 要求和的數組
* @param n 所要求的前n個元素
* @return 返回前n個元素的和
*/
int sum(int test[],int n){
if(n <= 0)
return 0;
return test[n-1]+sum(test,n-1);
}
~~~
下面是我的程序的輸出,這個程序比較簡單。

- 前言
- 實例一:HelloWorld
- scanf函數學習
- 實數比較
- sizeof()保留字獲取類型的大小
- 自增/自減學習
- C學習if條件判斷和for循環
- C實現的九九乘法表
- C實現一個比較簡單的猜數游戲
- 使用C模擬ATM練習switch..case用法
- 記錄一個班級的成績練習一維數組
- C數組實現矩陣的轉置
- C二維數組練習
- 利用數組求前n個質數
- C實現萬年歷
- C實現數組中元素的排序
- C實現任意進制數的轉化
- C判斷一個正整數n的d進制數是否是回文數
- C使用遞歸實現前N個元素的和
- 鋼材切割問題
- 使用指針比較整型數據的大小
- 指向數組的指針
- 尋找指定元素
- 尋找相同元素的指針
- 整數轉換成羅馬數字
- 字符替換
- 從鍵盤讀入實數
- C實現字符行排版
- C實現字符排列
- C實例--判斷一個字符串是否是回文數
- 通訊錄的輸入輸出
- 撲克牌的結構定義
- 使用“結構”統計學生成績
- 報數游戲
- 模擬社會關系
- 統計文件中字符個數
- C實現兩個文件的內容輸出到同一個屏幕