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

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

計(jì)算組合數(shù)

2019-11-10 19:09:41
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

編寫(xiě)函數(shù),參數(shù)是兩個(gè)非負(fù)整數(shù)n和m,返回組合數(shù)(符號(hào)不會(huì)打(⊙﹏⊙)b)!!!

很簡(jiǎn)單是吧,正好用到了剛才的階乘。

#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;}

但,發(fā)現(xiàn)WA了。。。

當(dāng)輸入哪n = 21,m = 1時(shí),輸出的是-1  明顯不對(duì)。說(shuō)明中間是結(jié)果溢出了。

那么,怎么解決呢?

我們可以約分。

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;}


發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 湘潭市| 汶上县| 壶关县| 察隅县| 三亚市| 东阿县| 咸丰县| 横山县| 玉树县| 聂拉木县| 新宁县| 宜良县| 汤阴县| 定州市| 翁源县| 迭部县| 伊金霍洛旗| 大石桥市| 华阴市| 瑞昌市| 公安县| 博湖县| 偃师市| 林芝县| 和平县| 济源市| 济南市| 寿光市| 浑源县| 洛扎县| 新蔡县| 穆棱市| 乌恰县| 黄陵县| 湖北省| 乐昌市| 诸城市| 康保县| 搜索| 南康市| 浙江省|