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

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

【二進制枚舉】求在n個數中取任意個數加起來組成x的方案數

2019-11-10 17:58:54
字體:
來源:轉載
供稿:網友

問題:n個互不重復的數,通過加法湊出X,求出有多少種方案?(1<=n<=20,1<=X<=2000)

輸入格式:n,x,n個整數

思路:由于n并不大,可以使用二進制枚舉的方法。簡單題,看代碼就能夠理解

#include <iostream>#include <algorithm>#include <vector>#include <stdio.h>#include <cstring>using namespace std;int num[21];int main(){        int n,x,i,j,temp,tot=0;        scanf("%d%d",&n,&x);        for(i=0;i<n;i++)scanf("%d",&num[i]);        for(i=0;i<(1<<n);i++)        {                temp=0;                for(j=0;j<n;j++)                {                        if(i&(1<<j))//判斷二進制i從右數第j+1位是否為1                                temp+=num[j];                }                if(temp==x)tot++;        }        PRintf("%d",tot);}


上一篇:SM2國密算法證書解析

下一篇:排序算法

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 手机| 余姚市| 哈尔滨市| 三穗县| 武鸣县| 静乐县| 榆中县| 旬邑县| 湘乡市| 鄂温| 临海市| 遵义县| 饶阳县| 庆云县| 封丘县| 巴彦淖尔市| 德兴市| 江山市| 东丽区| 若羌县| 元谋县| 乐昌市| 政和县| 新河县| 大埔县| 平罗县| 板桥市| 贵州省| 稻城县| 九龙城区| 梓潼县| 静海县| 宕昌县| 吉木乃县| 盘山县| 阜平县| 正蓝旗| 岑溪市| 枣强县| 高尔夫| 南和县|