NOIP模拟82
T1 魔法
解题思路
发现选择情况无非就是两种,连续的一段或者间隔为 \(R+B\) 的倍数的一段。
直接对于原序列贪心,每次选择可以消除的部分并将其删掉。
对于合法的情况将操作倒序输出即可。
code
#include<bits/stdc++.h>
#define int long long
#define ull unsigned long long
#define f() cout<<"Failed"<<endl
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
return x*f;
}
const int N=1e5+10;
int n,r,b,head,tail,cntr,cntb,que[N];
char ch[N];
vector<int> ans;
void print()
{
printf("YES\n%lld",n/(r+b));
for(int i=n-1;~i;i--)
{
if((n-i-1)%(r+b)==0) printf("\n");
printf("%lld ",ans[i]);
}
}
bool solve_front()
{
multiset<int> res;
for(int i=1;i<=n;i++) res.insert(i);
while(res.size())
{
bool flag=false; head=1; tail=cntr=cntb=0;
for(auto it=res.begin();it!=res.end();it++)
{
int i=(*it); que[++tail]=i; cntr+=(ch[i]=='R'); cntb+=(ch[i]=='B');
if(tail>r+b) cntr-=(ch[que[head]]=='R'),cntb-=(ch[que[head]]=='B'),head++;
if(cntr==r&&cntb==b&&tail>=r+b){flag=true;break;}
}
if(!flag) return false;
for(int i=head;i<=tail;i++)
ans.push_back(que[i]),
res.erase(res.find(que[i]));
}
return true;
}
#undef int
int main()
{
#define int long long
freopen("magic.in","r",stdin); freopen("magic.out","w",stdout);
n=read(); r=read(); b=read(); scanf("%s",ch+1);
for(int i=1;i<=n;i++) cntr+=(ch[i]=='R'),cntb+=(ch[i]=='B');
if((!r&&cntr)||(!b&&cntb)) printf("NO"),exit(0);
if((r&&cntr%r)||(b&&cntb%b)) printf("NO"),exit(0);
if(solve_front()) print();
else printf("NO");
return 0;
}
T2 连通性
解题思路
\(f(n,m)\) 表示 \(n,m\) 对应的答案, \(g(n)\) 表示点数为 \(n\) 的合法无向图的个数。
\(g(n)\) 可以通过容斥求出来,钦定枚举 1 所在联通块的点的大小
\]
对于 \(f(n,m)\) 的转移考虑两种情况
全部是没有循环到的点的联通块: \(\sum\limits_{i=1}^m f(n-i,m-i)\binom{m-1}{i-1}\)
计算联通块内有循环到的点的情况钦定 \(n\) 节点在最后一个: \(\sum\limits_{i=1}^m\sum\limits_{j=1}^{n-m}f(n-i-j,m-j)\binom{m-1}{i-1}\binom{n-m}{j}g(j)\times(2^j-1)^i\times 2^{\frac{(i-1)i}{2}}\)
第二个柿子的后半部分就是联通块内与外面的有连边的点数方案数,以及所连的点的方案数。
code
#include<bits/stdc++.h>
#define int long long
#define ull unsigned long long
#define f() cout<<"Failed"<<endl
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
return x*f;
}
const int N=110,mod=1e9+7;
int T,n,m,p2[N*N],f[N][N],g[N],h[N][N],fac[N],ifac[N];
int C(int x,int y){return fac[x]*ifac[y]%mod*ifac[x-y]%mod;}
int power(int x,int y,int p=mod)
{
int temp=1;
while(y)
{
if(y&1) temp=temp*x%p;
x=x*x%p; y>>=1;
}
return temp;
}
int dfs(int n,int m)
{
if(~f[n][m]) return f[n][m];
if(!m) return f[n][m]=p2[n*(n-1)/2];
int rec=0;
for(int i=1;i<=m;i++) rec=(rec+dfs(n-i,m-i)*C(m-1,i-1))%mod;
for(int i=1;i<=m;i++) for(int j=1;j<=n-m;j++) rec=(rec+dfs(n-i-j,m-i)*C(m-1,i-1)%mod*C(n-m,j)%mod*h[i][j])%mod;
return f[n][m]=rec;
}
#undef int
int main()
{
#define int long long
freopen("floyd.in","r",stdin); freopen("floyd.out","w",stdout);
memset(f,-1,sizeof(f)); f[1][0]=f[0][0]=f[1][1]=1;
fac[0]=ifac[0]=p2[0]=1; for(int i=1;i<=100;i++) fac[i]=fac[i-1]*i%mod;
ifac[100]=power(fac[100],mod-2); for(int i=99;i>=1;i--) ifac[i]=ifac[i+1]*(i+1)%mod;
for(int i=1;i<=10000;i++) p2[i]=p2[i-1]*2%mod;
for(int i=1;i<=100;i++) g[i]=p2[i*(i-1)/2];
for(int i=1;i<=100;i++) for(int j=1;j<i;j++) g[i]=(g[i]-g[j]*p2[(i-j)*(i-j-1)/2]%mod*C(i-1,j-1)%mod+mod)%mod;
for(int i=1;i<=100;i++) for(int j=1;j<=100;j++) h[i][j]=g[j]*power(p2[j]-1,i)%mod*p2[i*(i-1)/2]%mod;
T=read(); while(T--) n=read(),m=read(),printf("%lld\n",dfs(n,m));
return 0;
}
T3 矩形
解题思路
发现对于 L 以及 R 所对应的数字可以通过二分求出来。
直接枚举所有的数字,查询排名在 L 和 R 之间的数字,向 L,R 中间填就好了
code
#include<bits/stdc++.h>
#define int long long
#define ull unsigned long long
#define f() cout<<"Failed"<<endl
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
return x*f;
}
const int N=3e5+10,INF=1e18,Lim=3e5*1e9;
int n,L,R,top,sta[N],s[N],l[N],r[N];
vector<int> ans;
int S(int x){return x<=0?0:x*(x+1)/2;}
int g(int w,int l,int r){return S(w)-S(w-l-1)-S(w-r-1)+S(w-l-r-2);}
int work(int x){if((--x)<=0)return 0;int sum=0;for(int i=1;i<=n;i++) sum+=g(min(x/s[i],r[i]-l[i]+1),i-l[i],r[i]-i);return sum;}
int divide(int num)
{
int li=0,ri=Lim,ans=0;
while(li<=ri)
{
int mid=(li+ri)>>1;
if(work(mid)<num) li=mid+1,ans=mid;
else ri=mid-1;
}
return ans;
}
#undef int
int main()
{
#define int long long
freopen("rectangle.in","r",stdin); freopen("rectangle.out","w",stdout);
n=read(); for(int i=1;i<=n;i++) s[i]=read(); L=read(); R=read();
sta[++top]=l[1]=1;
for(int i=2;i<=n;i++)
{
while(top&&s[i]<s[sta[top]]) r[sta[top--]]=i-1;
l[i]=sta[top]+1; sta[++top]=i;
}
while(top) r[sta[top--]]=n;
int posl=divide(L),posr=divide(R),ending=min(R,work(posl+1));
for(int i=L;i<=ending;i++) ans.push_back(posl);
for(int i=1;i<=n;i++)
{
int up=max(r[i]-i+1,i-l[i]+1),down=min(r[i]-i+1,i-l[i]+1);
int fro=posl/s[i]+1,to=min(r[i]-l[i]+1,(posr-1)/s[i]),cnt;
for(int j=fro;j<=to;j++)
{
cnt=(j<=down)?j:(j<=up?down:r[i]-l[i]-j+2);
while(cnt--) ans.push_back(j*s[i]);
}
}
while(ans.size()<=R-L) ans.push_back(posr); sort(ans.begin(),ans.end());
for(int i=0;i<ans.size();i++) printf("%lld ",ans[i]);
return 0;
}
T4 排列
大坑未补
NOIP模拟82的更多相关文章
- NOIP 模拟4 T2
本题属于二和一问题 子问题相互对称 考虑对于问题一:知a求b 那么根据b数组定义式 显然能发现问题在于如何求dis(最短路) 有很多算法可供选择 dijsktra,floyed,bfs/dfs,spf ...
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程
数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...
- 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...
- 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...
- 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...
- CH Round #58 - OrzCC杯noip模拟赛day2
A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...
- CH Round #52 - Thinking Bear #1 (NOIP模拟赛)
A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...
随机推荐
- Ajax 原理是什么?如何实现?
一.是什么 AJAX全称(Asynchronous Javascript And XML) 即异步的JavaScript 和XML,是一种创建交互式网页应用的网页开发技术,可以在不重新加载整个网页的情 ...
- 力扣704(java&python)-二分查找(简单)
题目: 给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1. 示例 1: 输入: ...
- Java工具篇之Disruptor高性能队列
简介: disruptor适用于多个线程之间的消息队列,`作用与ArrayBlockingQueue有相似之处`,但是disruptor从功能.性能都远好于ArrayBlockingQueue,当多个 ...
- mPaas 研发流程和线上运维介绍
简介: mPaas 研发流程和线上运维介绍 一. 背景 金融级移动开发平台 mPaaS[1](Mobile PaaS)为 App 开发.测试.运营及运维提供云到端的一站式解决方案,能有效降低技术门槛. ...
- OpenTelemetry 简析
简介: OpenTelemetry 是 CNCF 的一个可观测性项目,旨在提供可观测性领域的标准化方案,解决观测数据的数据模型.采集.处理.导出等的标准化问题,提供与三方 vendor 无关的服务. ...
- Flow vs Jenkins 实操对比,如何将Java应用快速发布至ECS
简介:Jenkins 由于其开源特性以及丰富插件能力,长久以来都是中小企业搭建 CICD 流程的首选.不过 Jenkins 存在维护成本高.配置复杂等缺点,云效 Flow 较好地解决了这些问题. 本 ...
- Quick BI的可视分析之路
简介: Quick BI是专为云上用户量身打造的智能数据分析和可视化BI产品,帮助企业快速完成从传统的数据分析到数据云化+分析云化的转变,将企业的业务数据产出后以最快的速度被推送到各组织侧消费使用.本 ...
- 2021年阿里云年中钜惠攻略,注册即可抽 iPhone 12 Pro 等好礼
简介: 七月流火,燃情盛夏!值此季节,阿里云又推出了年中钜惠,精选百款产品,助力创业新势力.从7月26日开始,每天上午10点.下午4点将会放出爆款产品,进行限量秒杀,大家不要错过.注册登陆还可抽取 i ...
- [FAQ] SSH 免密登录主机/服务器 怎么操作 ?
1. 生成公私钥对,保存好. 命令:ssh-keygen -t rsa -C "xxx" 2. 将公钥传到远程主机的 ~/.ssh/authorized_keys 之中. 命令:s ...
- 异构数据源同步之表结构同步 → 通过 jdbc 实现,没那么简单
开心一刻 今天坐沙发上看电视,旁边的老婆拿着手机贴了过来 老婆:老公,这次出门旅游,机票我准备买了哈 我:嗯 老婆:你.我.你爸妈.我爸妈,一共六张票 老婆:这上面还有意外保险,要不要买? 我:都特么 ...