国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C > 正文

使用C語言求N的階乘的方法

2020-01-26 14:58:34
字體:
來源:轉載
供稿:網友

用遞歸法求N的階乘

程序調用自身稱為遞歸( recursion).它通常把一個大型復雜的問題層層轉化為一個與原問題相似的規模較小的問題來求解.

遞歸的能力在于用有限的語句來定義對象的無限集合。

一般來說,遞歸需要有邊界條件、遞歸前進段和遞歸返回段。當邊界條件不滿足時,遞歸前進;當邊界條件滿足時,遞歸返回。

#include <stdio.h>#include <string.h>#include <stdlib.h>long factorial(int n){  if(n == 1)    return 1;  else    return n*factorial(n-1);}int main(int argc,char *argv[]){  int n = 0;  if(argc != 2)  {    printf("input error,exit!!/n");    return -1;  }  n = atoi(argv[1]);  printf("%d! = %ld/n",n,factorial(n));  return 0;}

習題示例

題目

    題目描述: 
     輸入一個正整數N,輸出N的階乘。 
    輸入: 
    正整數N(0<=N<=1000) 
    輸出: 
     輸入可能包括多組數據,對于每一組輸入數據,輸出N的階乘 
    樣例輸入: 
    4 
    5 
    15 
    樣例輸出: 
    24 
    120 
    1307674368000 

AC代碼

  #include <stdio.h>   #include <stdlib.h>   #include <string.h>       #define MAX 3000       //存儲每次階乘運算的結果   int str[MAX];       void calculateFactorial(int n);       int main()   {     int n;         while (scanf("%d", &n) != EOF) {       if(n == 0) {         printf("1/n");       } else {         calculateFactorial(n);       }     }         return 0;   }       void calculateFactorial(int n)   {     int i, j, temp, c, len;         memset(str, 0, sizeof(str));     str[1] = 1;         for (i = 2, len = 1; i <= n; i ++) { //循環與2,3,..n相乘       for (j = 1, c = 0; j <= len; j ++) { //str數組代表一個數,模擬與i相乘         temp = str[j] * i + c;         str[j] = temp % 10;         c = temp / 10;       }       while(c > 0)       {         str[j ++] = c % 10;         c /= 10;       }       len = j - 1;     }         for (i = len; i >= 1; i --) {       printf("%d", str[i]);     }     printf("/n");   } 

    /**************************************************************
        Problem: 1076
        User: wangzhengyi
        Language: C
        Result: Accepted
        Time:2150 ms
        Memory:916 kb
    ****************************************************************/

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 库车县| 崇左市| 沙田区| 潢川县| 阳江市| 泊头市| 昌邑市| 长岛县| 陈巴尔虎旗| 洛南县| 建宁县| 浮山县| 西城区| 道孚县| 宜城市| 郧西县| 丹寨县| 前郭尔| 东明县| 凤山市| 枞阳县| 郯城县| 麻江县| 晴隆县| 天峨县| 沾化县| 新昌县| 仁化县| 雷州市| 巴林右旗| 建德市| 房产| 六盘水市| 桐庐县| 安阳县| 陕西省| 石泉县| 同心县| 罗田县| 澄江县| 泗阳县|