小米2018秋招笔试题之24点

有n个1~23的整数,写一个算法,求出有多少个相互不同的子集合的和为24点。

 

输入描述:

输入数据包含一组
每组的第一行包括一个整数n(1 <= n <= 23)
第二行包括n个整数1 <= 整数 <= 23)

输出描述:

对于每个测试实例,要求输出能组成24点的所有子集合的数量(子集合相互不同)。如果不存在,则输出0。每个测试实例的输出占一行。

示例1

输入

4
1 2 22 23

输出

2

知识点:深搜,set集合存储不重复数据(子集)

#include <bits/stdc++.h>
using namespace std;
int a[30],n;
set<set<int> > S;
void dfs(int sum,int pos, set<int> s) {
    if(pos == n + 1) return;
    if(sum == 24) {
        S.insert(s);
        return;
    }
    dfs(sum, pos + 1, s);
    s.insert(a[pos]);
    dfs(sum + a[pos],pos + 1, s);
}
int main()
{
    scanf("%d",&n);
    for(int i = 0; i < n; i++){
        scanf("%d",&a[i]);
    }
    set<int> s;
    dfs(0,0,s);
    printf("%d\n",(int)S.size());
    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值