【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. 833. Find And Replace in String —— weekly contest 84

    Find And Replace in String To some string S, we will perform some replacement operations that replac ...

  2. swjtuoj2433 Magic Mirror

    描述 Magic Mirror is an artificial intelligence system developed by TAL AI LAB,It can determine human ...

  3. .NET Core 跨平台资源监控库及 dotnet tool 小工具

    目录 简介 dotnet tool 体验 CZGL.SystemInfo SystemPlatformInfo ProcessInfo 内存监控 NetworkInfo DiskInfo 简介 CZG ...

  4. SQL存储过程返回值

    1 SQL存储过程返回值有3种 1.1 直接return返回(例如 return 1): 1.2 通过参数output返回(例如字符串类型): 1.3 直接返回程序集(Dataset程序集). 2 用 ...

  5. 为什么layui表单不显示?

    当你使用表单时,Layui会对select.checkbox.radio等原始元素隐藏,从而进行美化修饰处理.但这需要依赖于form组件,所以你必须加载 form,并且执行一个实例.值得注意的是:导航 ...

  6. javascript中什么是函数

    函数的定义 在javascript中函数是一段可以被执行或调用任意次数的JavasScript代码,在数据类型中属于"function".函数也拥有属性和方法,因此函数也是对象. ...

  7. Zabbix实现电话告警通知的配置方法分享

    如果要讨论下当下热门的监控系统,我想zabbix应该能够占有自己的一席之地,拥有不小的话语权吧.然而身为一名苦逼的运维,为了不错过重大的告警信息,就需要配置个[电话告警]来进行最快速的通知. zabb ...

  8. Databricks说的Lakehouse是什么?

    在过去的几年里,Lakehouse作为一种新的数据管理范式,已独立出现在Databricks的许多用户和应用案例中.在这篇文章中,我们将阐述这种新范式以及它相对于之前方案的优势. 数据仓库在决策支持和 ...

  9. 为什么Redis是单线程?

    转载链接:https://cloud.tencent.com/developer/article/1120615 1)以前一直有个误区,以为:高性能服务器 一定是多线程来实现的 原因很简单因为误区二导 ...

  10. 在iOS 4中创建一个LDGradientView样式的渐变视图

    本教程将演示如何在 Swift 4 中创建一个多功能的.@IBDesignable 样式的渐变视图类.你可以将 CAGradientView 放到 storyboard 中,并在设计时预览,或者以编程 ...