麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發(fā)設計 > 正文

計算組合數

2019-11-10 19:19:47
字體:
來源:轉載
供稿:網友

編寫函數,參數是兩個非負整數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;}

但,發(fā)現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;}


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 91免费高清视频 | 成人富二代短视频 | 日韩精品一二三 | 久久精品国产久精国产 | 嗯~啊~用力~高h | 国产小视频在线 | 国产无限资源在线观看 | 久草手机在线 | 香蕉久久久久 | 欧美日韩在线视频一区 | 一级裸体视频 | 一级电影在线观看 | 一区二区三区无码高清视频 | 天天鲁在线视频免费观看 | 国产午夜亚洲精品理论片大丰影院 | 免看黄大片aa | 日韩视频一二区 | 全网免费毛片 | 麻豆porn| 91九色视频| 国产毛片在线看 | 欧美一级黄色片在线观看 | 羞羞视频免费观看入口 | 国产精品免费麻豆入口 | 最近国产中文字幕 | 国产一区二区视频网站 | 国产精品久久久久久久久久久久久久久久 | 成人av一区二区免费播放 | 羞羞视频免费观看入口 | 毛片免费在线观看 | 日韩精品免费一区二区三区 | 成人国产精品久久 | 国产一区二区三区四区五区加勒比 | 一级一级一级一级毛片 | 国产一区二区三区手机在线 | 一本色道久久综合亚洲精品小说 | 久久国产免费视频 | 国产欧美亚洲精品a | 成人午夜一区二区 | 一边吃奶一边插下面 | 国产午夜精品一区二区三区四区 |