连续段的期望

【问题描述】

小N最近学习了位运算,她发现2个数xor之后数的大小可能变大也可能变小,and之后都不会变大,or之后不会变小。于是她想算出以下的期望值:现在有 N个数排成一排,如果她随意选择一对l,r并将下标在l和r中间(包括l,r)的数(xor,and,or)之后,期望得到的值是多少呢?取出每一对l,r 的概率都是相等的。小G认为这太easy了,容易被你们水过去,因此你需要告诉他所有选择情况下,(xor,and,or)值的和。

【输入格式】

第一行1个正整数N。

第二行N个非负整数代表数列。

【输出格式】

共两行六个数。

第一行3个数,分别表示xor的期望,and的期望,or的期望,保留3位小数。

第二行3个数,分别表示xor的和,and的和,or的和。

【输入样例】

2

4 5

【输出样例】

2.750 4.250 4.750

11 17 19

【数据规模】

30%数据中1<=N<=1000

对于另外的30%数据数列中只包含0和1

对于100%的数据1<=N<=100000,数列中的数 <= 10^9

【样例解释】

l, r xor and or

1,1 4 4 4

1,2 1 4 5

2,1 1 4 5

2,2 5 5 5

每一组l,r取的概率都是相同的,xor=(4+1+1+5)/4=2.750 其他同理

【得分说明】

第一行三个数每个数正确得两分。

第二行三个数每个数正确得一分。

第二行三个数全部正确再得一分。

分析

考虑dp。

用\(f(n,31)\)表示以n为右端点的区间中,各个二进制位上的1的个数。

然后就可以很方便的转移。时间复杂度\(O(31n)\)

#include<bits/stdc++.h>
using namespace std;
template<class T>T read(T&x)
{
T data=0;
int w=1;
char ch=getchar();
while(!isdigit(ch))
{
if(ch=='-')
w=-1;
ch=getchar();
}
while(isdigit(ch))
{
data=data*10+ch-'0';
ch=getchar();
}
return x=data*w;
}
typedef long long ll; const int N=1e5+7;
int n,a[N];
int f[N][31];
ll s1,s2,s3; int main(){
freopen("nine.in","r",stdin);
freopen("nine.out","w",stdout);
// cerr<<int(1<<30)<<endl;
read(n);
for(int i=1;i<=n;++i)
read(a[i]);
// xor
for(int i=1;i<=n;++i)
for(int j=0;j<31;++j)
{
if(a[i]>>j&1)
f[i][j]=(i-1-f[i-1][j])+1;
else
f[i][j]=f[i-1][j];
s1+=(1LL<<j)*f[i][j];
// cerr<<i<<" "<<j<<" f="<<f[i][j]<<endl;
}
s1*=2;
for(int i=1;i<=n;++i)
s1-=a[i];
// cerr<<"s1="<<s1<<endl; // and
memset(f,0,sizeof f);
for(int i=1;i<=n;++i)
for(int j=0;j<31;++j)
{
if(a[i]>>j&1)
f[i][j]=f[i-1][j]+1;
else
f[i][j]=0;
s2+=(1LL<<j)*f[i][j];
}
s2*=2;
for(int i=1;i<=n;++i)
s2-=a[i]; // or
memset(f,0,sizeof f);
for(int i=1;i<=n;++i)
for(int j=0;j<31;++j)
{
if(a[i]>>j&1)
f[i][j]=i;
else
f[i][j]=f[i-1][j];
s3+=(1LL<<j)*f[i][j];
}
s3*=2;
for(int i=1;i<=n;++i)
s3-=a[i]; printf("%.3lf %.3lf %.3lf\n",double(s1)/n/n,double(s2)/n/n,double(s3)/n/n);
// printf("%lld %lld %lld\n",s1,s2,s3);
return 0;
}

test20181219 连续段的期望的更多相关文章

  1. 区间的连续段~ST表(模板题)

    链接:https://www.nowcoder.com/acm/contest/82/B来源:牛客网 时间限制:C/C++ 7秒,其他语言14秒 空间限制:C/C++ 262144K,其他语言5242 ...

  2. 牛客82-B:区间的连续段 (ST表,贪心)(WXK牛逼)

    题目描述 给你一个长为n的序列a和一个常数k 有m次询问,每次查询一个区间[l,r]内所有数最少分成多少个连续段,使得每段的和都 <= k 如果这一次查询无解,输出"Chtholly& ...

  3. 牛客练习赛14 B 区间的连续段 (倍增)

    链接:https://ac.nowcoder.com/acm/contest/82/B来源:牛客网 区间的连续段 时间限制:C/C++ 7秒,其他语言14秒 空间限制:C/C++ 262144K,其他 ...

  4. 牛客练习赛14B 区间的连续段

    题目链接 点我跳转 题目大意 给定一个长度为 \(N\) 的序列 \(A\) 和一个常数 \(K\) 有 \(M\) 次询问 每次询问查询一个区间 \([L , R]\) 内所有数最少分成多少个连续段 ...

  5. P2486 [SDOI2011]染色(树剖)区间覆盖+区间的连续段

    https://www.luogu.org/problemnew/show/P2486 值的一看https://www.cnblogs.com/Tony-Double-Sky/p/9283262.ht ...

  6. 【XSY3344】连续段 DP 牛顿迭代 NTT

    题目大意 对于一个长度为 \(n\) 的排列 \(p\),我们称一个区间 \([l,r]\) 是连续的当且仅当 \((\max_{l\leq i\leq r}a_i)-(\min_{l\leq i\l ...

  7. 牛客练习赛9 B - 珂朵莉的值域连续段

    题目描述 珂朵莉给你一个有根树,求有多少个子树满足其内部节点编号在值域上连续 一些数在值域上连续的意思即其在值域上构成一个连续的区间 输入描述: 第一行有一个整数n,表示树的节点数.接下来n–1行,每 ...

  8. codedecision P1112 区间连续段 题解 线段树

    题目描述:https://www.cnblogs.com/problems/p/P1112.html 题目链接:http://codedecision.com/problem/1112 线段树区间操作 ...

  9. P1112 区间连续段

    题目描述 给你一个长度为n的数组 \(a_1, a_2, \dots a_n\) . 一开始这n个元素都为0. 然后有m次操作,每次操作有两种操作类型: update x y a:将区间 \([x,y ...

随机推荐

  1. FAQ | 是什么导致MySQL数据库服务器磁盘I/O高(本文章来自知数堂)

    FAQ | 是什么导致MySQL数据库服务器磁盘I/O高 2016-12-26 叶金荣 老叶茶馆 0.导读 有个MySQL服务器的磁盘I/O总有过高报警,怎么回事? 本文约1500字,阅读时间约10分 ...

  2. const修饰的常量 不能被直接修改 但是可以通过指针进行间接修改

    大家都知道如下代码中,被const限定的a是不可以被直接修改的 void main() { const int a = 3; a=1; } 在C++中const修饰的常量,不能被直接修改,但是可以通过 ...

  3. J2EE--Hibernate基础笔记

    因为写的是基础内容,所以在这里,(映射集合.映射组件.复合主键和联合主键,jpa annotation,关联映射,hql等等实用内容)都不会提到- 这里写的就是试用李刚<J2EE实战>那本 ...

  4. 实验四Android开发

    实验四Java Android简易开发 实验准备 Android Studio 的下载: Android Studio 安装教程 在安装过程中的问题: 在下载了官网上的说明包含sdk的安装包之后找不到 ...

  5. 判断当前html是否在微信中打开

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...

  6. MQ 个人小结

    在PCS项目: talking 发送队列1.1 创建@Beanpublic Queue orderTakingQueue() { return createQueue(orderTakingQueue ...

  7. Image合并添加文字内容

    场景:将一个头像.二维码.文字信息添加到一张背景图片中,将这些信息合成一张图片. 代码已经测试验证.代码中图片自己随意找几张测试即可. 代码: import com.sun.image.codec.j ...

  8. Ajax-04 jQuery Ajax 常用操作

    jQuery jQuery 其实就是一个JavaScript的类库,其将复杂的功能做了上层封装,使得开发者可以在其基础上写更少的代码实现更多的功能. jQuery Ajax a.概述 jQuery 不 ...

  9. 【python】self用法详解

    在介绍Python的self用法之前,先来介绍下Python中的类和实例我们知道,面向对象最重要的概念就是类(class)和实例(instance). 类是抽象的模板,比如学生这个抽象的事物,可以用一 ...

  10. IE浏览器兼容 css之bug 问题

    bug的几种常见原因: 1.盒模型bug      原因:没有正确声明doctype(如果没有声明doctype,各浏览器对代码的解析有不同的规范).解决方法:使用严格的doctype声明. 2.各浏 ...