【JZOJ6233】【20190627】心的旋律
题目
你需要构造一个\(n\)个点的二分图
定义\(F(A)\)表示左部点集\(A\)能够到达的右部中的点
使得满足 $ F(A) \lt |A| $ 的集合恰好有 $ k $ 个
\(1 \le n \le 32 \ , \ 0 \le k \le 2^n\)
题解
当$A = \emptyset $ 时满足\(F(A) \lt |A|\) ,当\(k = 2^n\)时无解
下面都考虑构造满足\(F(A) \ge |A|\) 的个数为\(k \ = \ 2^n - k\)
另\(F_{i+1}\)表示第\(i\)个点的F集合,令$ F_{i+1} \supset F_{i} $ ,记\(d_i = |F_{i}|\),即\(d_{i+1}-d_i = 0 / 1\)
那么结论是$d_i $的 \(2^n\) 个取值恰好一一对应了$ 1 \to 2 ^ n $ 的 $ k $ 值
并且存在一个更强的结论
证明:
考虑如何计算一个\(d_i\)的方案:\[\begin{align}
F&= \sum_{i=1}^{n} \sum_{j=1}^{d_i}(^{i-1}_{j-1})\\
&= \sum_{i=1}^{m} (^n_i) - (^{B_i - 1}_{\ \ \ i}) \\
\end{align}
\]记 $ d_i =1 $ 的位置为 $ B_ 1 \ , \ \cdots \ , \ B_m $ ,只需要证明
(注意组合数的一个竖列和主对角线求和是可化简的)
*1.若\(m_1 \lt m_2\) ,则\(F_1 \lt F_2\)
不妨考虑\(m , m + 1\) \(m \lt n\)
$F_{m+1} - F_{m} \ge (^n _m) - [ (^{n-m}_1 )+ ({n-m-1}_2)+\cdots+({n-1}_m) ] = (^{n-m-1}_0) \ge 1 $
由于前一半是和\(B_i\)独立的,所以多加一位的贡献可以覆盖后一半的贡献
*2.\(m_1=m_2\),记\(d_i\)形成的二进制数\(D1 \gt D2\) ,则\(F_1 \lt F_2\)
不妨考虑二进制位\(i\)和\(i+1\)的贡献 \((i \ge m)\)
\(F_{i} - F_{i+1} \ge (^i_m) - [(^{i-m}_1) +\cdots + (^{i-2}_{m-1}) + (^{i-1}_m) ] = (^{i-m}_0) \ge 1\)
说明二进制位不同可以覆盖后面所有二进制位的贡献
可以说明上面的所有结论
Code
#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int N=33;
typedef pair<ll,ll>pii;
int n,d[N];ll K,C[N][N];
pii a[N];
int main(){
freopen("circle.in","r",stdin);
freopen("circle.out","w",stdout);
scanf("%d%lld",&n,&K);
K=(1ll<<n)-K;
if(!K)puts("-1"),exit(0);
int cnt=0;
for(int i=0;i<=n;++i)C[i][0]=1;
for(int i=1;i<=n;++i)
for(int j=1;j<=n;++j)C[i][j]=C[i-1][j-1]+C[i-1][j];
for(cnt=0;C[n][cnt]<K;K-=C[n][cnt++]);
for(int i=n,now=0;i&&now<cnt;--i){
if(C[i-1][cnt-now-1]<K)K-=C[i-1][cnt-now-1];
else now++,d[i]=1;
}
for(int i=1;i<=n;++i)d[i]+=d[i-1];
for(int i=1;i<=n;++i,puts(""))
for(int j=1;j<=n;++j)printf(j<=d[i]?"1 ":"0 ");
return 0;
}
【JZOJ6233】【20190627】心的旋律的更多相关文章
- pygame系列_原创百度随心听音乐播放器_完整版
程序名:PyMusic 解释:pygame+music 之前发布了自己写的小程序:百度随心听音乐播放器的一些效果图 你可以去到这里再次看看效果: pygame系列_百度随心听_完美的UI设计 这个程序 ...
- 【breathandlife】气势磅礴、比较好听的旋律有哪些?
[breathandlife]气势磅礴.比较好听的旋律有哪些? 分享:yunbest作者:来源:2015-10-26 专题:breathandlife [breathandlife]气势磅礴.比较好听 ...
- [deviceone开发]-心形点赞动画示例
一.简介 这个示例展示do_Animator组件的简单使用,通过点击"点赞"按钮,不断弹出心形图片,向上动画漂移到顶部消失.间隔时间和上下左右移动的步长都是一定范围的随机值.二.效 ...
- BZOJ 后缀自动机四·重复旋律7
后缀自动机四·重复旋律7 时间限制:15000ms 单点时限:3000ms 内存限制:512MB 描述 小Hi平时的一大兴趣爱好就是演奏钢琴.我们知道一段音乐旋律可以被表示为一段数构成的数列. 神奇的 ...
- WPF 如何画一颗心
如何用WPF画一个心. MainWindow.xaml <Window x:Class="Heart.MainWindow" xmlns="http://schem ...
- 你的眼睛背叛你的心:解决 .NET Core 中 GetHostAddressesAsync 引起的 EnyimMemcached 死锁问题
在我们将站点从 ASP.NET + Windows 迁移至 ASP.NET Core + Linux 的过程中,目前遇到的最大障碍就是 —— 没有可用的支持 .NET Core 的 memcached ...
- fir.im Weekly - 暖心的 iOS 持续集成,你值得拥有
一则利好消息,flow.ci 支持 iOS 项目持续集成,想试试的伙伴去 Gitter群 问问.首批尝鲜用户@阿米amoy 已经用 flow.ci 实现了基本的 iOS 持续集成,并详细记录整个 Bu ...
- CSS3制作心形头像
1.功能需求: 最近有一个基于微信开发的Mobile Web项目,是一个活动页面.功能需求:用户使用微信扫描二维码,然后授权使用微信登录,然后读取用户的昵称和头像,然后显示在一个饼图上面.头像需要有一 ...
- 如何用Python实现杨辉三角和心
1. 如何实现杨辉三角 import copy list=[] newlist=[] def Fibonacci(list,n): newlist.append(0) if n ==1: return ...
随机推荐
- [转] Vue原理解析——自己写个Vue
一.Vue对比其他框架原理 Vue相对于React,Angular更加综合一点.AngularJS则使用了“脏值检测”. React则采用避免直接操作DOM的虚拟dom树.而Vue则采用的是 Obje ...
- latex中添加C++代码
用到listings宏包,模板如下: \documentclass[UTF8]{ctexart} \usepackage[a4paper,top=2cm,bottom=2cm,left=2cm,rig ...
- 浅谈 G1 GC 日志格式
在 Java9 中,G1 GC 将成为默认的垃圾收集器,G1 垃圾收集器的关键特性之一是能够在不牺牲吞吐量的同时,限制 GC 暂停时间(即可以设置所需的最大停顿时间). 由于 G1 GC 正在逐渐成为 ...
- httpclient cer
X509Certificate2 cer = new X509Certificate2(@"path", "********", X509KeyStorageF ...
- 40、js技巧(持续更新。。。)
1.深拷贝对象: const a={name:'aaa',age:11} const b=JSON.parse(JSON.stringify(a)) 2.获取数组极值: let list = [1, ...
- 记录下Hbuilder 打包IOS发布时 总是提示错误:ios prifile文件与私钥证书匹配 的问题
最近两天,新的APP准备要上线,然后打包正式发布版 时,总是提示不匹配 证书照hbuilder里面的文档 一样也不行,然后百度了N种方法,都是不行,而且也比较少搜索到相关问题. 后来都是谷歌了下,找到 ...
- linux route路由
网关(Gateway)又称网间连接器.协议转换器.网关在网络层以上实现网络互连 就好像一个房间可以有多扇门一样,一台主机可以有多个网关.默认网关的意思是一台主机如果找不到可用的网关,就把数据包发给默认 ...
- Windows 10 下 GCC / LLVM 的安装和使用
win10下gcc的安装和makehttps://www.jianshu.com/p/46824c62dfed 方案1:直接官方下载安装minGw或Cygwininstall download: ht ...
- MobX入门示例
在相当长的一段时间内,Redux 都是前端开发人员作为状态管理的首先框架,如果不会 Redux,你都不好意思跟别人说自己是搞前端的. 没过多久,开发者们开始意识到,这东西虽说盛行,但它并没有传说中的那 ...
- Java开发环境之Tomcat
查看更多Java开发环境配置,请点击<Java开发环境配置大全> 壹章:Tomcat安装教程 1)去官网下载安装包 http://tomcat.apache.org/ 建议下载压缩包(zi ...