hpuoj 1192: Sequence

来源:互联网 发布:微盘交易源码下载 编辑:程序博客网 时间:2024/05/22 08:04

点击打开链接

1192: Sequence [组合数学]

时间限制: 3 Sec 内存限制: 128 MB

提交: 150 解决: 57 统计

题目描述

在某个夜黑高的晚上,!!!,原谅我编不下去了


很美吧?放松之后,继续做题吧。

HS(Handsome)的Ocean在纸上写下NN个整数,Ocean把它定义为OO序列。

Ocean认为一个序列的价值的是:序列中不同元素个数。

现在他想知道OO序列中所有子序列的价值之和


比如说:序列(1,1,2,2)(1,1,2,2)价值为22,因为序列中有1122两个不同元素。
比如序列(1,1,1)(1,1,1),共有77个子序列,(1)(1)(1)(1,1)(1,1)(1,1)(1,1,1)(1)、(1)、(1)、(1,1)、(1,1)、(1,1)、(1,1,1)。价值之和为77

输入

第一行输入一个整数TT,代表有TT组测试数据。
每组数据占两行,第一行输入一个整数NN,代表序列元素个数。
接下来一行输入NN个整数aiai

注:1<=T<=100001<=N<=501<=ai<=101<=T<=10000,1<=N<=50,1<=ai<=10。

输出

对每组测试数据,输出一个结果代表所有子序列价值之和。由于结果会很大,请用longlonglonglong(%lld)。

样例输入

431 1 141 1 1 1410 10 10 8201 2 3 4 5 6 7 8 9 10 1 2 3 4 5 6 7 8 9 10

样例输出

715227864320
题解:这题就是递推

下面是代码:

#include<cstdio>#include<cstring>#include<cmath>#include<cstdlib>#include<algorithm>using namespace std;int num[50];long long a[50];int main(){int T;scanf("%d",&T);while(T--){memset(num,0,sizeof(num));     memset(a,0,sizeof(a));long long n,b,s=0,ans=0,endd;scanf("%lld",&n);for(int i = 0 ; i < n ; i++){scanf("%lld",&b);num[b]++;}for(int i= 1 ; i <=10 ; i++){s++;if(num[i]!=0){endd=pow(2,num[i])-1;for(int  j = s ; j >= 1 ; j--){if(j==1)a[j]+=endd;elsea[j]+=a[j-1]*endd;}}}for(int i = 1 ; i <= s ; i++){if(a[i])ans+=a[i]*i;}printf("%lld\n",ans);}return 0;}




原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 跑步后脸上出盐怎么办 头发被剪的很短怎么办 孩子做事情拖拉不专注怎么办 新热水壶有味道怎么办 新买电热壶有味怎么办 两个月狗耳朵臭怎么办 狗狗牙齿变黄怎么办 人用了狗沐浴露怎么办 狗狗吞食牙膏吐怎么办? 狗狗吞食了牙膏怎么办 大猪拉稀不吃食怎么办 猪不发烧不吃食怎么办 天天吃自热米饭怎么办 喝了加热包水怎么办啊 蛋挞没有盒子装怎么办 塑料饭盒盖子被吸住了怎么办 火腿淹的有臭味怎么办 微波炉热饭盖子打不开怎么办 夏天带饭容易馊怎么办? 保温饭盒里有气打不开怎么办 保温饭盒摔了一下打不开怎么办 饭盒跟盖子盖一起打不开怎么办 玻璃杯子盖被水吸住打不开怎么办 电饭煲热剩饭没加水怎么办 微波炉碗盖子吸住了怎么办 微波炉转饭盖子吸住了怎么办 玻璃碗放进微波炉打不开怎么办 乐扣微波炉加热后打不开怎么办 美的微波炉盖子打不开怎么办 美的微波炉门都打不开了怎么办 饭煮好了有异味怎么办 一正常吃饭就胖怎么办 高铁盒饭没15的怎么办 上火车前票丢了怎么办 减肥期吃了汉堡怎么办 寿司店鳗鱼有刺怎么办 吃泡面胃难受该怎么办 吃上火的东西脸上长痘痘怎么办 减肥期间吃撑了怎么办 喝了变质的牛奶怎么办 绿豆糕吃多了会怎么办