【题解】Counting D-sets(容斥+欧拉定理)

没时间写先咕咕咕。

vjCodeChef - CNTDSETS

就是容斥,只是难了一二三四五\(\dots \inf\)点

题目大意:

给定你一个\(n\)维空间,问你这个空间内有多少个点集满足两点间最大的切比雪夫距离为\(d\)。两个点集不同,当且仅当两个点集无法通过平移而想等。

转化1

考虑最后那个限制,平移想等的限制,受这道题的启发【题解】At2370 Piling Up,我们考虑钦定每一维的\(0\)点都有点坐落,这样就钦定了一个基准,问题就转变成了要求每维都有\(0\),且存在某个点的某维坐标为\(d\),且\(d\)是所有数里最大的。

转化2

此类题有一个套路,就是当它钦定最大最小为\(d\)的时候的方案数,可以等于\([0,d]\)的随机分配\(-[0,d-1]\)的随机分配,这样减出来的方案就保证了一定有点在\(d\)空间的边界上,不然一定会被减去。

转化3

所以我们答案就是\(f(d)-f(d-1)\),其中\(f(d)\)表示\(n\)维空间的每维在\([0,d]\)中随意分配坐标的方案数。此时我们发现仍然有问题,因为我们还没有钦定每一维有\(0\)。

考虑我们如何钦定每一维都有零,显然不能一个组合数直接钦定,因为可能一个点的坐标有多个\(0\),这个情况我们考虑不到。但是可以发现每一维本质相同的(意思是可以通过组合数来计算方案),所以可以\(O(n)\)容斥。考虑我们容斥什么,我们容斥钦定每至少i维没有\(0\),最后我们要的是\(0\)维没有\(0\)。

转换4

我们看一个点的坐标,写成这个形式\(p(x_1,x_2,x_3,x_4\dots x_n),x_i\in [0,d],x_i \in N^+\),那么由\(p\)构成的点集的方案是多少呢,我想啊想想不出来就去看题解去了。题解告诉我,这个的方案数是

\[2^{(d+1)^n}
\]

傻逼了。其实很简单,总共有\((d+1)^n\)个点,枚举每个点放不放即可,注意包括了一个也不放的方案。

那么如何钦定至少\(i\)没有\(0\)呢?很简单,钦定\(x_i\in[1,d]\)就好了。那么这个的方案就是

\[{n \choose i}2^{d^i(d+1)^{n-i}}
\]

乘上一个组合数枚举哪些维度没有\(0\)。

所以最终\(f(x)=\)

\[\sum_{i=0}^n (-1)^i{n \choose i}2^{d^i(d+1)^{n-i}}
\]

所以最终答案\(=f(d)-f(d-1)\)

转换5

看答案那个式子,你发现你要到指数上面取膜,你很害怕,因为你好像不知道指数上取膜的运算规则。这就\(naive\)了,模数是\(1e9+7\)是个质数,现在你发现欧拉定理有用了,因为

\[a^{\phi(p)} \equiv 1 \mod p
\]

而质数中,\(\phi(p)=p-1\)。所以你在指数上就直接对\(1e9+6\)取膜就好了。

//@winlere
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm> using namespace std; typedef long long ll;
inline int qr(){
register int ret=0,f=0;
register char c=getchar();
while(c<48||c>57)f|=c==45,c=getchar();
while(c>=48&&c<=57) ret=ret*10+c-48,c=getchar();
return f?-ret:ret;
}
const int mod=1e9+7;
inline int Pow(int base,const int&p){
register int ret=1;
for(register int t=p;t;t>>=1,base=1ll*base*base%mod)
if(t&1) ret=1ll*ret*base%mod;
return ret;
} const int mod2=mod-1;
inline int zhiPow(int base,const int&p){
register int ret=1;
for(register int t=p;t;t>>=1,base=1ll*base*base%mod2)
if(t&1) ret=1ll*ret*base%mod2;
return ret; } const int maxn=1e3+5;
int jc[maxn],inv[maxn];
int n,d;
inline int c(const int&n,const int&m){
if(n<m)return 0;
return 1ll*jc[n]*inv[m]%mod*1ll*inv[n-m]%mod;
}
inline int F(const int&x){
register int ret=0;
for(register int t=0,delta;t<=n;++t){
delta=1ll*c(n,t)*Pow(2,(1ll*zhiPow(x,t)*zhiPow(x+1,n-t))%mod2)%mod;
if(t&1) delta=mod-delta;
ret=(ret+delta)%mod;
}
return ret;
} int main(){
#ifndef ONLINE_JUDGE
freopen("in.in","r",stdin);
//freopen("out.out","w",stdout);
#endif
int T=qr();
jc[0]=inv[0]=1;
for(register int t=1;t<maxn;++t)
jc[t]=1ll*jc[t-1]*t%mod,inv[t]=Pow(jc[t],mod-2);
while(T--){
n=qr(),d=qr();
cout<<((F(d)-F(d-1))%mod+mod)%mod<<endl;
}
return 0;
}
Status Accepted
Memory 15257kB
Length 1546
Lang C++14(gcc 6.3)
Submitted 2019-06-13 17:44:16
Shared Yes
RemoteRunId 24729181

【题解】Counting D-sets(容斥+欧拉定理)的更多相关文章

  1. bzoj 1914: [Usaco2010 OPen]Triangle Counting 数三角形 容斥

    1914: [Usaco2010 OPen]Triangle Counting 数三角形 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 272  Sol ...

  2. CF 449D 题解(状压+容斥)

    状压妙啊... 本题的主体思路:状压+容斥原理(或状压+数位dp) 记g[i]表示按位与后结果所有位上至少有i个1的方案数 那么根据容斥原理,ans=g[0]-g[1]+g[2]-g[3]+g[4]. ...

  3. CF990G GCD Counting 点分治+容斥+暴力

    只想出来 $O(nlogn\times 160)$ 的复杂度,没想到还能过~ Code: #include <cstdio> #include <vector> #includ ...

  4. How Many Sets I(容斥定理)

    题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3556 How Many Sets I Time Limit: 2 ...

  5. kth min_max容斥

    题解: 普通的$min-max$容斥是用来求最后出现元素的期望之类的 $kth min-max$容斥进一步解决倒数第k个出现的元素的期望 给出公式: $kthmax(S)=\sum\limits_{T ...

  6. 【CF900D】Unusual Sequences 容斥(莫比乌斯反演)

    [CF900D]Unusual Sequences 题意:定义正整数序列$a_1,a_2...a_n$是合法的,当且仅当$gcd(a_1,a_2...a_n)=x$且$a_1+a_2+...+a_n= ...

  7. 【BZOJ2839】集合计数(容斥,动态规划)

    [BZOJ2839]集合计数(容斥,动态规划) 题面 BZOJ 权限题 Description 一个有N个元素的集合有2^N个不同子集(包含空集),现在要在这2^N个集合中取出若干集合(至少一个),使 ...

  8. 【BZOJ4596】黑暗前的幻想乡(矩阵树定理,容斥)

    [BZOJ4596]黑暗前的幻想乡(矩阵树定理,容斥) 题面 BZOJ 有\(n\)个点,要求连出一棵生成树, 指定了一些边可以染成某种颜色,一共\(n-1\)种颜色, 求所有颜色都出现过的生成树方案 ...

  9. loj2542 「PKUWC2018」随机游走 MinMax 容斥+树上高斯消元+状压 DP

    题目传送门 https://loj.ac/problem/2542 题解 肯定一眼 MinMax 容斥吧. 然后问题就转化为,给定一个集合 \(S\),问期望情况下多少步可以走到 \(S\) 中的点. ...

随机推荐

  1. 模糊测试工具Simple Fuzzer

    模糊测试工具Simple Fuzzer   模糊测试是一种不同于渗透测试的漏洞检测方式.它向目标系统发送各种非预期的输入,然后通过监视异常结果来发现漏洞.Kali Linux虽然作为渗透测试系统平台, ...

  2. BZOJ 4543 2016北京集训测试赛(二)Problem B: thr 既 长链剖分学习笔记

    Solution 这题的解法很妙啊... 考虑这三个点可能的形态: 令它们的重心为距离到这三个点都相同的节点, 则其中两个点分别在重心的两棵子树中, 且到重心的距离相等; 第三个点可能在重心的一棵不同 ...

  3. my-> git使用笔记

    要在本地新建分支test0227并切换到该分支,运行git checkoutout 并加上-b参数,如: git checkout -b test0227 这相当于执行下面这两条命令: git bra ...

  4. iOS申请证书,Certificates, Identifiers &Profiles 简介 - 申请证书

    在真机调试以及发布应用时,要申请证书,我们必须知道Certificates, Identifiers ,Profiles 是什么含义,下面对它们做简单介绍,以及如果申请证书. Certificates ...

  5. iphone/iOS 访问本地数据库sqlite3

    Phone也支持访问本地数据库Sqlite 3.这里简单的介绍一下iPhone上Sqlite 3的使用方法. 首先需要在项目中引用Sqlite 3的开发包,下面是在iPhone SDK 3.0下的目录 ...

  6. django常用第三方app大全

    djangoapp 资源大全 最近经常在这个版面看到Django相关扩展的介绍,而其一个扩展写一个帖子,觉得没太必要吧. 以前整理的django资源列表,从我的wiki上转过来的. 要找django资 ...

  7. SVN源码服务器搭建-详细教程

    一.引言 笔者曾经试图在网上搜索一篇关于SVN源代码服务器搭建方面的中文技术文章,可惜,所找到的,要么是不完整,要么就是对笔者没什么帮助的文章,TortoiseSvn的帮助文档固然强大,但因为是英文, ...

  8. 深入Java----集合----BitSet

    BitSet类    大小可动态改变, 取值为true或false的位集合.用于表示一组布尔标志. java中有三种移位运算符 <<      :     左移运算符,num <&l ...

  9. 跨域问题解决方式(HttpClient安全跨域 &amp; jsonp跨域)

    1 错误场景 今天要把项目部署到外网的时候,出现了这种问题, 我把两个项目放到自己本机的tomcat下, 进行代码调试, 执行 都没有问题的, 一旦把我须要调用接口的项目B放到其它的server上, ...

  10. 【Python】使用scatter()绘制散点图

    绘制简单散点图 要绘制单个点,使用scatter()函数,并向它传递一对x和y坐标,它将在指定位置绘制一个点 import matplotlib.pyplot as plt plt.scatter(2 ...