程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 更多關於編程 >> C++求階乘的兩種方法

C++求階乘的兩種方法

編輯:更多關於編程

     這篇文章主要介紹了C++求階乘的兩種方法,有需要的朋友可以參考一下

    1.使用靜態局部變量static 靜態局部變量在函數調用結束之後不消失而保留原值,即其占用的存儲單元不釋放,在下一次該函數調用時,該變量保留上一次函數調用結束時的值。   靜態局部變量賦初值實在編譯時進行的,即只賦初值一次,在程序運行時它已有初值。   code:   代碼如下: #include<iostream> using namespace std; int fac(int n) {  static int f=1;  f=f*n;  return f; } int main() {  int i;  for(i=1;i<=5;i++)  {   cout<<i<<"!="<<fac(i)<<endl;  }  return 0; }     print:    代碼如下: /* 1!=1 2!=2 3!=6 4!=24 5!=120 */     2.使用遞歸的方法 首先進行退出遞歸的判斷,然後進行遞歸   code:   代碼如下: #include<iostream> using namespace std; int fac(int n) {  if(n<0) return 0;  if(n==0||n==1)return 1;  if(n>1)  {   return n*fac(n-1);  } } int main() {  int i;  for(i=1;i<=5;i++)  {   cout<<i<<"!="<<fac(i)<<endl;  }  return 0; }     print:   代碼如下: /* 1!=1 2!=2 3!=6 4!=24 5!=120 */    
    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved