组合问题的算法实现

16 篇文章 0 订阅
/*
问题描述:对于一组各不相同的数字,从中任意抽取1-n个数字,构成一个新的集合。
求出所有的可能的集合。例如,对于集合{1,2,3},其所有子集为{1},{2},{3},{1,2},{1,3},{2,3}{1,2,3}, 
给定一个数组(元素各不相同),求出数组的元素的所有非空组合(即数组的所有非空子集)
解法:位向量法。用一个辅助数组表示各个元素的状态。1表示在集合中,0表示不在数组中。递归地求解所有的子集。
算法描述如下://这里的算法对空集也输出了,可修改之使得只输出非空集合。
*/

#include <iostream>
using namespace std;
void getSubset(int list[],bool v[],int a,int b){
	if(a == b){
		for(int i = 0; i < b; i++){
			if(v[i])
			cout<<list[i]<<"  ";
		}
		cout<<endl;
		return;
	}
	v[a] = true;
	getSubset(list,v,a+1,b);
	v[a] = false;
	getSubset(list,v,a+1,b);

}
int main(){
    int li[] = {1,2,3,4};
    bool v[] = { false,false,false,false};
    getSubset(li,v,0,4);
}

/*
USER_ID: icpc#2017pre2015140537
PROBLEM: 1471
SUBMISSION_TIME: 2017-04-02 14:37:55

#include <iostream>
#include <vector>
#define MOD 1000000007
using namespace std;
vector<vector<long long> > muliMatrix(const vector<vector<long long> > &m1, const vector<vector<long long> > &m2) {
    vector<vector<long long> > res(m1.size() ,vector<long long>(m2[0].size(), 0));
    for (int i = 0; i < m1.size(); i++) {
        for (int j = 0; j < m2[0].size(); j++) {
            for (int k = 0; k < m2.size(); k++) {
                res[i][j] += (m1[i][k] * m2[k][j]);
            }
            res[i][j] = res[i][j] % MOD;
        }
    }
    return res;
}
     
vector<vector<long long> > matrixPower(const vector<vector<long long> > &m, long long p) {
    vector<vector<long long> > res(2 ,vector<long long>(2, 0));
     
    for (int i = 0; i < res.size(); i++) res[i][i] = 1;
    vector<vector<long long> > tmp(m);
    for(; p != 0; p >>= 1) {
        if ((p & 1) != 0) res = muliMatrix(res, tmp);
        tmp = muliMatrix(tmp, tmp);
    }
    return res;
}
int main()
{
    long long n;
    cin >> n;
    if (n == 0) cout << 1 << endl;
    else {
        vector<vector<long long> > v(2, vector<long long>(2, 0));
        v[0][0] = 2;
        v[0][1] = 1;
        v[1][0] = 3;
        v[1][1] = 0;   
        vector<vector<long long> > res = matrixPower(v, n - 1);
        cout << ((res[0][0] + res[1][0]) % MOD)<< endl;
    }
    return 0;
}

*/

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值