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

首頁 > 學院 > 開發設計 > 正文

計算組合數

2019-11-10 21:49:34
字體:
來源:轉載
供稿:網友

編寫函數,參數是兩個非負整數n和m,返回組合數(符號不會打(⊙﹏⊙)b)!!!

很簡單是吧,正好用到了剛才的階乘。

#include<iostream>using namespace std;long long factorial(int n){    long long m=1;    for(int i=1;i<=n;i++){        m*=i;    }    return m;}long long C(int n,int m){    return factorial(n)/(factorial(m)*factorial(n-m));}int main(){
        int n,m; while(cin>>n>>m){ cout<<C(n,m)<<endl; } return 0;}

但,發現WA了。。。

當輸入哪n = 21,m = 1時,輸出的是-1  明顯不對。說明中間是結果溢出了。

那么,怎么解決呢?

我們可以約分。

n!/m!=(m+1)(m+2)...(n-1)n;

所以,代碼如下:

#include<iostream>using namespace std;long long C(int n,int m){    if(m<n-m)        m=n-m;    long long ans = 1;    for(int i=m+1;i<=n;i++)        ans*=i;    for(int i=1;i<=n-m;i++)        ans/=i;    return ans;}int main(){    int n,m;    while(cin>>n>>m){        cout<<C(n,m)<<endl;    }    return 0;}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 监利县| 开封市| 屏南县| 泾阳县| 正定县| 礼泉县| 乌拉特后旗| 浮山县| 乌拉特前旗| 行唐县| 大同县| 和龙市| 兴安县| 那曲县| 甘谷县| 德庆县| 客服| 哈尔滨市| 苗栗市| 无锡市| 盐山县| 和林格尔县| 新巴尔虎左旗| 名山县| 贵德县| 漳浦县| 柘荣县| 静海县| 香河县| 乌鲁木齐县| 林西县| 安岳县| 岱山县| 满城县| 海林市| 太和县| 明光市| 九龙县| 张家口市| 晋州市| 长泰县|