【NOIP2017提高A组模拟9.7】JZOJ 计数题

题目

Description

Input

Output

Sample Input

5

2 2 3 4 5

Sample Output

8

6

Data Constraint

题解

题意

给出\(a[i]\),有一完全图,\(i\)与\(j\)之间的边的值为\(a[i] \oplus a[j]\)(\(\oplus\)为异或的意思)

求最小生成树及方案数

题解

科普一个东西,\(n\)个点的完全图的生成树个数是\(n^{n-2}\)

这个东西叫做凯莱定理,大家可以自行了解一下

100\(\%\)

看到异或,而且要最小,且\(a[i]\)二进制做多只有30位

想到可以按照最高位往下分治,分成当前这位是0和1的两堆,然后为了取值最小,那么这两堆只能连一条

那么就找到这两堆里面异或值最小的,这是\(trie\)应用的经典问题

然后分治一位一位往下

最后把所有最小值加一起,方案数乘起来即可

Code

#include<cmath>
#include<cstdio>
#include<algorithm>
#define mod 1000000007
using namespace std;
long long n,mx,num,ans,ans1,tot,a[1000001],er[31],c1[1000001],c2[1000001];
struct node
{
long long left,right,size;
}trie[400005];
long long read()
{
long long res=0;char ch=getchar();
while (ch<'0'||ch>'9') ch=getchar();
while (ch>='0'&&ch<='9') res=(res<<1)+(res<<3)+(ch-'0'),ch=getchar();
return res;
}
void insert(long long x)
{
long long now=1;
++trie[now].size;
for (long long i=mx;i>=0;--i)
{
if (x&er[i])
{
if (trie[now].left==0) trie[now].left=++num,trie[num].left=trie[num].right=trie[num].size=0;
now=trie[now].left;
++trie[now].size;
}
else
{
if (trie[now].right==0) trie[now].right=++num,trie[num].left=trie[num].right=trie[num].size=0;
now=trie[now].right;
++trie[now].size;
}
}
}
long long calc(long long x)
{
long long now=1,s=0;
for (long long i=mx;i>=0;--i)
{
if (x&er[i])
{
if (trie[trie[now].left].size>0) now=trie[now].left;
else s+=er[i],now=trie[now].right;
}
else
{
if (trie[trie[now].right].size>0) now=trie[now].right;
else s+=er[i],now=trie[now].left;
}
}
tot=trie[now].size;
return s;
}
long long ksm(long long x,long long y)
{
long long res=1;
while (y)
{
if (y&1) res=res*x%mod;
x=x*x%mod;
y>>=1;
}
return res;
}
long long dg(long long l,long long r,long long d)
{
if (r<=l) return 1;
if (d<0) return ksm(r-l+1,r-l-1);
long long t1=0,t2=0;
for (long long i=l;i<=r;++i)
{
if (a[i]&er[d]) c1[++t1]=a[i];
else c2[++t2]=a[i];
}
for (long long i=1;i<=t1;++i)
a[l+i-1]=c1[i];
for (long long i=1;i<=t2;++i)
a[l+t1+i-1]=c2[i];
long long s1=dg(l,l+t1-1,d-1),s2=dg(l+t1,r,d-1);
long long s3=(s1*s2)%mod,s4=2147483647,s5=0;
if (t1==0||t2==0) return s3;
num=1;
trie[1].left=trie[1].right=trie[1].size=0;
for (long long i=1;i<=t1;++i)
insert(a[l+i-1]);
for (long long i=1;i<=t2;++i)
{
long long sum=calc(a[l+t1+i-1]);
if (sum<s4) s4=sum,s5=tot;
else if (sum==s4) s5=(s5+tot)%mod;
}
ans+=s4;
return (s3*s5)%mod;
}
int main()
{
freopen("jst.in","r",stdin);
freopen("jst.out","w",stdout);
n=read();
for (long long i=1;i<=n;++i)
a[i]=read(),mx=max(mx,a[i]);
mx=log2(mx);
er[0]=1;
for (long long i=1;i<=31;++i)
er[i]=er[i-1]*2%mod;
num=1;
ans1=dg(1,n,mx);
printf("%lld\n%lld\n",ans,ans1);
fclose(stdin);
fclose(stdout);
return 0;
}

【NOIP2017提高A组模拟9.7】JZOJ 计数题的更多相关文章

  1. JZOJ 【NOIP2017提高A组模拟9.14】捕老鼠

    JZOJ [NOIP2017提高A组模拟9.14]捕老鼠 题目 Description 为了加快社会主义现代化,建设新农村,农夫约(Farmer Jo)决定给农庄里的仓库灭灭鼠.于是,猫被农夫约派去捕 ...

  2. JZOJ 100029. 【NOIP2017提高A组模拟7.8】陪审团

    100029. [NOIP2017提高A组模拟7.8]陪审团 Time Limits: 1000 ms  Memory Limits: 131072 KB  Detailed Limits   Got ...

  3. JZOJ 5328. 【NOIP2017提高A组模拟8.22】世界线

    5328. [NOIP2017提高A组模拟8.22]世界线 (File IO): input:worldline.in output:worldline.out Time Limits: 1500 m ...

  4. JZOJ 5329. 【NOIP2017提高A组模拟8.22】时间机器

    5329. [NOIP2017提高A组模拟8.22]时间机器 (File IO): input:machine.in output:machine.out Time Limits: 2000 ms M ...

  5. JZOJ 5307. 【NOIP2017提高A组模拟8.18】偷窃 (Standard IO)

    5307. [NOIP2017提高A组模拟8.18]偷窃 (Standard IO) Time Limits: 1000 ms Memory Limits: 262144 KB Description ...

  6. JZOJ 5286. 【NOIP2017提高A组模拟8.16】花花的森林 (Standard IO)

    5286. [NOIP2017提高A组模拟8.16]花花的森林 (Standard IO) Time Limits: 1000 ms Memory Limits: 131072 KB Descript ...

  7. JZOJ 5305. 【NOIP2017提高A组模拟8.18】C (Standard IO)

    5305. [NOIP2017提高A组模拟8.18]C (Standard IO) Time Limits: 1000 ms Memory Limits: 131072 KB Description ...

  8. 【NOIP2017提高A组模拟9.17】信仰是为了虚无之人

    [NOIP2017提高A组模拟9.17]信仰是为了虚无之人 Description Input Output Sample Input 3 3 0 1 1 7 1 1 6 1 3 2 Sample O ...

  9. 【NOIP2017提高A组模拟9.17】猫

    [NOIP2017提高A组模拟9.17]猫 题目 Description 信息组最近猫成灾了! 隔壁物理组也拿猫没办法. 信息组组长只好去请神刀手来帮他们消灭猫.信息组现在共有n 只猫(n 为正整数) ...

随机推荐

  1. FloodFill算法详解及应用

    啥是 FloodFill 算法呢,最直接的一个应用就是「颜色填充」,就是 Windows 绘画本中那个小油漆桶的标志,可以把一块被圈起来的区域全部染色. 这种算法思想还在许多其他地方有应用.比如说扫雷 ...

  2. ElasticSearch7.3破解

    破解ES7.3.0到白金版(学习交流使用) 正常安装ELK7.3版本到服务器上 正常部署ELK7到服务器上,先不要启动.然后开始进行破解操作 进行破解操作 需要破解的文件:modules/x-pack ...

  3. 最简单的基于FFmpeg的直播系统开发移动端例子:IOS 视频解码器

    本文记录IOS平台下基于FFmpeg的视频解码器.该示例C语言的源代码来自于<最简单的基于FFMPEG+SDL的视频播放器>.相关的概念就不再重复记录了. 源代码 项目的目录结构如图所示. ...

  4. Python基础学习之常用模块

    1. 模块 告诉解释器到哪里查找模块的位置:比如sys.path.append('C:/python') 导入模块时:其所在目录中除源代码文件外,还新建了一个名为__pycache__ 的子目录,这个 ...

  5. Python专题之详解enumerate和zip

    enumerate 第一个是枚举函数. 在我们的日常编程过程中,我们经常遇到一个问题. 在C语言和一些古老的语言中没有迭代器的概念,所以当我们想要遍历数组或容器时,我们只能使用下标.使用迭代器,我们的 ...

  6. Qt基础之菜单栏

    本篇介绍Qt菜单栏相关操作,分为三部分:1.菜单栏相关的类介绍:2.系统菜单的生成和响应:3.弹出菜单的生成和响应:菜单栏通常只有以QMainWindow为基类的程序中才用到,以QWidget为基类的 ...

  7. WEB安全问题

    WEB安全问题我没太多经验,但是这块内容还是很重要,所以必须要了解学习一下. 简单总结了一下,分成以下5类, 1.DDOS,瘫痪式攻击,解决方法是记录异常请求的ip地址,主动拒绝或者将攻击ip添加到防 ...

  8. http代理阅读2

    向上游服务器发送请求处理 static void ngx_http_upstream_send_request(ngx_http_request_t *r, ngx_http_upstream_t * ...

  9. IP 层收发报文简要剖析6--ip_forward 报文转发

    //在函数ip_route_input_slow->ip_mkroute_input注册, /* * IP数据包的转发是由ip_forward()处理,该函数在ip_rcv_finish() * ...

  10. 你要的SSM(Spring+Springmvc+Mybatis)小项目来了!!!

    SSM-Maven-Heima 这是一个使用 SSM(Spring+Springmvc+Mybatis)框架的商城小项目,使用Maven构建项目,以MySQL为数据库系统,Redis的缓存服务器(并不 ...