hdu5496 Beauty of Sequence
Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 383    Accepted Submission(s): 167
the beauty of the sequence.
Now you are given a sequence A of n integers {a1,a2,...,an}.
You need find the summation of the beauty of all the sub-sequence of A.
As the answer may be very large, print it modulo 109+7.
Note: In mathematics, a sub-sequence is a sequence that can be derived from another sequence by deleting some elements without changing the order of the remaining elements. For example {1,3,2} is
a sub-sequence of {1,4,3,5,2,1}.
indicating the number of test cases. For each test case:
The first line contains an integer n (1≤n≤105),
indicating the size of the sequence. The following line contains n integers a1,a2,...,an,
denoting the sequence(1≤ai≤109).
The sum of values n for
all the test cases does not exceed 2000000.
a single line.
5
1 2 3 4 5
4
1 2 1 3
5
3 3 2 1 2
54
144
这题看了好长时间题解,终于理解了。因为子序列太多,所以可以考虑每一个元素贡献的价值,对于每个数, 我们只算它出现在连续相同元素的第一个时的贡献, 这样会使计算简便很多. 假设当前的数是a[i], 那么i后面的数可以随便选有2^(n-i)种. 考虑a[i]前面的数, 要么一个不选, 要么选择的最后一个数和a[i]不同, 那么我们只要把前面出现过的i的位置记录下来,分别为b,c,d,..那么总的个数为2^(i-1)-2^(b-1)-2^(c-1)-...这样就可以算出来了。
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<stack>
#include<string>
#include<algorithm>
using namespace std;
#define ll long long
#define inf 0x7fffffff
#define maxn 100070
#define MOD 1000000007
map<int,int>mp;
map<int,int>::iterator it;
ll a[maxn],cishu[maxn];
ll kuaisumi(ll a,ll b,int c)
{
  ll ans = 1;
  a=a%c;
  while(b>0)
  {
      if(b%2==1)
      ans=(ans*a)%c;
      b=b/2;
      a=(a*a)%c;
  }
  return ans;
}
ll mul(ll x){
    return kuaisumi(2,x,MOD);
}
int main()
{
    ll m,i,j,T;
    ll n;
    scanf("%lld",&T);
    while(T--)
    {
        scanf("%lld",&n);
        for(i=1;i<=n;i++){
            scanf("%lld",&a[i]);
        }
        memset(cishu,0,sizeof(cishu));
        mp.clear();
        ll ans=0;
        for(i=1;i<=n;i++){
            if(!mp.count(a[i])){
                ans=(ans+a[i]*mul(n-1))%MOD;
            }
            else{
                ans=(ans+ a[i]*( mul(i-1)-mp[a[i] ])%MOD*mul(n-i)%MOD  )%MOD;
            }
            mp[a[i] ]=(mp[a[i] ]+mul(i-1) )%MOD;
        }
        printf("%lld\n",(ans+MOD)%MOD);
    }
    return 0;
}
hdu5496 Beauty of Sequence的更多相关文章
- hdu-5496 Beauty of Sequence(递推)
		题目链接: Beauty of Sequence Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K (Java ... 
- HDU 5496 Beauty of Sequence
		题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5496 Beauty of Sequence Problem Description Sequence ... 
- HDU 5496——Beauty of Sequence——————【考虑局部】
		Beauty of Sequence Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Other ... 
- Hdu 5496 Beauty of Sequence (组合数)
		题目链接: Hdu 5496 Beauty of Sequence 题目描述: 一个整数序列,除去连续的相同数字(保留一个)后,序列的和成为完美序列和.问:一个整数序列的所有子序列的完美序列和? 解题 ... 
- HDU 5496 - BestCoder Round #58 - Beauty of Sequence
		题目链接 : http://bestcoder.hdu.edu.cn/contests/contest_chineseproblem.php?cid=637&pid=1002 思路 : 考 ... 
- CF&&CC百套计划3 Codeforces Round #204 (Div. 1)  D. Jeff and Removing Periods
		http://codeforces.com/problemset/problem/351/D 题意: n个数的一个序列,m个操作 给出操作区间[l,r], 首先可以删除下标为等差数列且数值相等的一些数 ... 
- HDU6592 Beauty Of Unimodal Sequence
		Beauty Of Unimodal Sequence 给一个序列,在满足单调递增或者单调递减或者先增后减的最长子序列集合里找到下标字典序最大以及最小的两个子序列,输出这两个子序列里元素的下标. n≤ ... 
- 2019年杭电多校第二场 1002题Beauty Of Unimodal Sequence(LIS+单调栈)
		题目链接 传送门 思路 首先我们对\(a\)正反各跑一边\(LIS\),记录每个位置在前一半的\(LIS\)中应该放的位置\(ans1[i]\),后一半的位置\(ans2[i]\). 对于字典序最小的 ... 
- codeforces 336C Vasily the Bear and Sequence(贪心)
		转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud Vasily the Bear and Sequence Vasily the b ... 
随机推荐
- Hive Query生命周期 —— 钩子(Hook)函数篇
			无论你通过哪种方式连接Hive(如Hive Cli.HiveServer2),一个HQL语句都要经过Driver的解析和执行,主要涉及HQL解析.编译.优化器处理.执行器执行四个方面. 以Hive目前 ... 
- 【Linux】CentOS7中修改中文字符集
			CentOS 7中字符集查看的方式是 locale -a 或者locale 如果想显示中文的话,应该修改为 LANG="zh_CN.UTF-8" 在命令行界面临时修改字符集的话 ... 
- leetcode 93. Restore IP Addresses(DFS, 模拟)
			题目链接 leetcode 93. Restore IP Addresses 题意 给定一段序列,判断可能组成ip数的所有可能集合 思路 可以采用模拟或者DFS的想法,把总的ip数分成四段,每段判断是 ... 
- SDUST数据结构 - chap7 图
			判断题: 选择题: 函数题: 6-1 邻接矩阵存储图的深度优先遍历: 裁判测试程序样例: #include <stdio.h> typedef enum {false, true} boo ... 
- 浅入深出了解XXE漏洞
			环境搭建 https://github.com/c0ny1/xxe-lab 为了更深入的理解,我准备理论和实际相结合的了解XXE! 浅谈XML 初识XML 一个好的代码基础能帮助你更好理解一类漏洞,所 ... 
- layui表格数据统计
			//执行一个 table 实例 table.render({ elem: '#demo' ,height: 420 ,url: '/demo/table/user/' //数据接口 ,title: ' ... 
- centos7虚拟机开启端口后 外部不能访问的问题
			转载 https://blog.csdn.net/u012045045/article/details/104219823 虚拟机新开了5005端口,系统内部是显示开了的(wget 192.168.4 ... 
- 微信登录2-生成授权URL
			一.准备工作 1.注册 微信开放平台:https://open.weixin.qq.com 2.邮箱激活 3.完善开发者资料 4.开发者资质认证 准备营业执照,1-2个工作日审批.300元 5.创建网 ... 
- 什么是 MVC 模式
			概述 MVC,即 Model 模型.View 视图,及 Controller 控制器. View:视图,为用高糊提供使用界面,与用户直接进行交互. Model:模型,承载数据,并对用户提交请求进行计算 ... 
- 在nodejs中创建cluster
			目录 简介 cluster集群 cluster详解 cluster中的event cluster中的方法 cluster中的属性 cluster中的worker 总结 在nodejs中创建cluste ... 
