数组中所有和为num的组合—去哪笔试题

第一行输入数组个数n和总数num;
第二行输入数组的元素;
求数组中是否存在相加为num的组合,如果存在输出”perfect”,如果不存在输出“good”。
输入:
5 200 
100 30 20 110 120
输出:
good

输入:
5 100 
10 30 20 40 50
输出:
perfect

#include<iostream>
#include<vector>
using namespace std;

int flag = 0;
void findFactor2(int sum, vector<int> num, int n) {
    if (sum<0 || n<0)
        return;
    if (sum == 0) {
        flag = 1;
        cout << "perfect" << endl;
        return;
    }
    findFactor2(sum - num[n], num, n - 1);//放n,n-1个数填满sum-n 
    findFactor2(sum, num, n - 1);//不放n,n-1个数填满sum   
}
int main(){
    int number, m;
    cin >> number >> m;
    vector<int> v(number);
    int i;
    int w0 = m;
    for (i = 0; i<number; i++) {
        cin >> v[i];
    }
    findFactor2(m, v, v.size()- 1);
    if (flag == 0)
        cout << "good" << endl;
    return 0;
}

延伸

输入两个整数 n 和 m,从数列1,2,3…….n 中 随意取几个数, 使其和等于 m ,要求将其中所有的可能组合列出来.

vector<int> factors;
void findFactor2(int sum,int n){
    if(sum<0||n<0)
        return ;
    if(sum==0){
        for(vector<int>::iterator iter=factors.begin();iter!=factors.end();++iter){
            cout<<*iter<<' ';
        }
        cout<<endl;
        return;
    }
    factors.push_back(n);//典型的01背包问题  
    findFactor2(sum-n,n-1);//放n,n-1个数填满sum-n 
    factors.pop_back();
    findFactor2(sum,n-1);//不放n,n-1个数填满sum   
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值