2021 CCPC 威海站 VP记录(题解)
2021 CCPC 威海站 VP记录(题解)
题目顺序为vp时开题顺序:
A - Goodbye, Ziyin!
签到,连边数小于等于2的可以作为二叉树根,若有大于4的直接输出0。
code:
void solve(){
int n;
cin >> n;
map<int,int> cnt;
for (int i = 0;i < n - 1;i ++) {
int x,y;
cin >> x >> y;
cnt[x]++;
cnt[y]++;
}
int ans = 0;
for (auto [u,v] : cnt) {
if(v >= 4) {
cout << 0 << endl;
return ;
}
else if(v <= 2) ans++;
}
cout << ans << endl;
}
J - Circular Billiard Table
分析:每次碰撞圆心角不会改变,根据这个性质,可以推出回到原点时一定走过了\(360^{\circ}\)的倍数,可以推出公式(代码来自队友)
code:
void car()
{
a*=2;
ll c=360*b;
ll d=c/__gcd(c,a)*a;
cout<<d/a-1<<endl;
}
signed main()
{
ios::sync_with_stdio(false);
cin>>t;
while(t--)
{
cin>>a>>b;
car();
}
cerr<<endl<<"carnation13"<<endl;
return 0;
}
M 810975
题意:n局游戏,赢了m场,连胜最多为k场,求最后方案数
分析:典型隔板法,如果没有连胜最多为k场这个条件,就是经典公式了\(ans = \binom{n - m}{n + m - 1}\)(发现离散学的这个公式蛮方便的)。解释下这个公式,其实就是隔板放球的模型,把赢得局想成球,输的局想成板,那就是\(n + m -1\)个地方放\(n - m\)个板(可重复组合问题)。
然后为了满足最多连胜为k场,在vp的时候和队友推了下感觉正推不好做,于是可以想到用容斥去算出来不合法的方案数,最后用总方案数减去不合法的方案数即可。
考虑不合法的方案数,我们可以这么考虑,有\(n - m + 1\)段是连胜的区间,那我们可以类似于devu和鲜花那题,把每一段恰好为\(k + 1\)的情况给算出来容斥掉,就是最后的答案了。
所以公式为:
\]
稍微解释一下,这里的\(i\)表示\(n + + m - 1\)段连胜段里选取\(i\)段,且这\(i\)段正好为连胜\(k + 1\)场的情况。
然后这个公式对应的是连胜最多场数小于等于\(k\)场的情况,减去小于等于\(k-1\)的方案数就是最后答案啦
int cal(int n,int m,int k) {
int res = 0;
res = C(n + m - 1,n - m);
int neg = 1;
for (int i = 0;i <= n - m + 1;i ++) {
// if(i * (k + 1) >= m) break;
res = (res + neg * C(n - m + 1 , i) % mod * C(n - i * (k + 1),n - m) % mod) % mod;
res = (res + mod) % mod;
neg = -neg;
}
return res;
}
void solve(){
int n,m,k;
cin >> n >> m >> k;
int ans = 0;
if(n < m || k > m) {
cout << 0 << endl;
return ;
}
ans = cal(n,m,k) - cal(n,m,k - 1);
ans = (ans % mod + mod) % mod;
cout << ans << endl;
}
G - Shinyruo and KFC
分析:非常明显的暴力题,题目限定了数据范围是所有数总和小于等于2e5,所以他肯定是两种情况,要么最大的数特别大,前面的都不用算,要么是最大的数不太大,会变成有点类似于分块的处理方法。在同一块内的组合数一起算掉就可以了(这其实是我赛场口胡的,队友听完后打了一个桶思想的代码顺利ac,可能直接看大佬队友的代码就可以了)
code:
signed main(){
init();
ios::sync_with_stdio(false);
cin.tie(nullptr);cout.tie(nullptr);
cin>>q>>w;
for(i=1;i<=q;i++)
{
cin>>f[i];
ton[f[i]]++;
}
sort(f+1,f+1+q);
for(i=1;i<=q;i++)
{
if(f[i]!=f[i-1])
cnt++;
g[cnt]=f[i];
}
maxn=min(g[cnt],w);
for(i=1;i<maxn;i++) cout<<0<<endl;
for(i=maxn;i<=w;i++)
{
ans=1;
for(int j=1;j<=cnt;j++)
{
//cout<<i<<" "<<f[j]<<" "<<C(i,f[j])<<endl;
ans=ans*qmi(C(i,g[j]),ton[g[j]])%mod;
}
cout<<ans<<endl;
}
}
D - Period
分析:哈希暴力水题,我队因为一直在想kmp做法一直wa(字符串确实不太会),后来发现暴力hash即可,没啥好说的看代码(来自队友)吧qwq(过的人第三多的签到题了)
code:
#include<bits/stdc++.h>
using namespace std;
typedef long long unsigned ll;
#define rep(i,a,b) for(ll i=a;i<=b;++i)
#define per(i,a,b) for(ll i=a;i>=b;--i)
const ll N=1000005,base=131,mod=212370440130137957ll;
ll n,m,k,q,now=0,c[N];
char s[N];
signed main()
{
//ios::sync_with_stdio(false);
scanf("%s",s+1);
n=strlen(s+1);
ll a=0,b=0,w=1;
for(ll i=1;i<=n;++i)
{
a=(a*base+s[i]);
//cout<<a<<" ";
b=((w*s[n-i+1])+b);
w=(w*base);
//cout<<b<<endl;
if(a==b)c[i]=++now;
else c[i]=now;
}
//for(ll i=1;i<=n;++i)cout<<c[i]<<" ";cout<<endl;
scanf("%lld",&q);
for(ll i=1;i<=q;++i)
{
ll x;
scanf("%lld",&x);
ll mi=min(x,n-x+1)-1;
printf("%lld\n",c[mi]);
}
//cerr<<endl<<"carnation13"<<endl;
return 0;
}
总结:新队伍的第二场vp,比上一场签完到就各种痛苦wa不会写的情况要好一点,五题其实是在三个小时多点的时候完成的,如果是实际比赛可能能出更多的题(可能吧),这个赛季加油了。
2021 CCPC 威海站 VP记录(题解)的更多相关文章
- 2018 CCPC 吉林站 H Lovers
2018 CCPC 吉林站 H Lovers 传送门:https://www.spoj.com/problems/LIS2/en/ 题意: q次操作 1.将第l~r个数的左边和和右边都加上一个数d, ...
- ccpc杭州站 赛后总结
Ccpc杭州站赛后总结 2017年11月4号五号,我参加了ccpc杭州站的比赛,我的队友是聂少飞和王艳,在4号一点半,举行了比赛开幕式,听着教练代表的发言,听着参赛选手代表的发言,听着志愿者的发言,都 ...
- 2018 CCPC 桂林站(upc复现赛)补题
2018 CCPC 桂林站(upc复现赛)补题 G.Greatest Common Divisor(思维) 求相邻数的差值的gcd,对gcd分解素因子,对所有的素因子做一次遍历,找出最小答案. 几个样 ...
- 2021 DevOpsDays 东京站完美收官 | CODING 专家受邀分享最新技术资讯
DevOpsDays 是一个全球知名的系列技术会议品牌,内容涵盖了软件开发.自动化.测试.安全.组织文化以及 IT 运营的社区会议等.DevOpsDays 由 DevOps 之父 Patrick De ...
- 2021.07.02 P1383 高级打字机题解(可持久化平衡树)
2021.07.02 P1383 高级打字机题解(可持久化平衡树) 分析: 从可以不断撤销并且查询不算撤销这一骚操作可以肯定这是要咱建一棵可持久化的树(我也只会建可持久化的树,当然,还有可持久化并查集 ...
- 2017 CCPC 哈尔滨站 题解
题目链接 2017 CCPC Harbin Problem A Problem B Problem D Problem F Problem L 考虑二分答案. 设当前待验证的答案为x 我们可以把第二 ...
- HDU 6240 Server(2017 CCPC哈尔滨站 K题,01分数规划 + 树状数组优化DP)
题目链接 2017 CCPC Harbin Problem K 题意 给定若干物品,每个物品可以覆盖一个区间.现在要覆盖区间$[1, t]$. 求选出来的物品的$\frac{∑a_{i}}{∑b_ ...
- 和jz姐姐的vp记录
即使如此,jz姐姐也漂亮的取得了胜利 有些懒得写直接口胡,所以代码也不一定有 暂时停更了 2015-2016 Petrozavodsk Winter Training Camp, Makoto rng ...
- CCPC 2020 长春站 部分简略题解
gym链接:CCPC 2020 changchun site A: 题目大意:商店里有若干个充值档位和首充奖励,你有\(n\)块钱问最多能拿到多少水. 解:由于档位不多可以直接枚举,整个二进制枚举一下 ...
随机推荐
- 服务器配置IP
1.服务器系统一般有两个或多个网卡.在企业中一般给服务器网卡配一个可连外网的IP,如172.16.20.22 255.255.255.0 172.16.20.1 方便联网下载安装部分软件,若没有VPN ...
- Redis-浅谈主从同步
主从库集群 Redis 提供了主从库模式,以保证数据副本的一致,在从库执行一下命令可以建立主从库关系: replicaof <dst ip> <dst port> Redis ...
- 技术分享 | 浅谈MySQL闪回的实现
欢迎来到 GreatSQL社区分享的MySQL技术文章,如有疑问或想学习的内容,可以在下方评论区留言,看到后会进行解答 1.闪回实现原理 2.binlog文件格式初探 3.闪回实现过程 1.闪回实现原 ...
- 开源云真机平台-Sonic应用实践
前言 Sonic是一款开源.支持分布式部署.在线自动化测试的私有云真机平台.偶然接触到这个平台是源于虫师的一篇公众号文章<基于Linux 部署 Sonic>,于是结合文章内容和官网尝试搭建 ...
- Excel 数学函数(二):ISODD 和 ISEVEN
ISODD 函数用于判断一个数是否为奇数:ISEVEN 函数用于判断一个数是否为偶数. 结合文本函数 MID 和逻辑函数 IF,来判断一个身份证的性别. 身份证倒数第二位是奇数就代表男性,否则代表女性 ...
- Git 使用技巧(一):合并分支
在合并分支之前最好保证你所有的分支都是最新的,所以你可以使用 git pull origin branchName 来拉取远程仓库到本地仓库. 假如有一个 dev 分支需要合并到 master 分支中 ...
- java过滤器的写法
↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓ 原文地址:http://t.csdn.cn/ZD88A ↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑ 过滤器实际上就是 ...
- 如何使用.NET 6的IHostedService和BackgroundService?
大家好,我是张飞洪,感谢您的阅读,我会不定期和你分享学习心得,希望我的文章能成为你成长路上的垫脚石,让我们一起精进. 本章是<定制ASP NET 6.0框架系列文章>的第七篇.本文内容和定 ...
- PyTorch中的CUDA操作
CUDA(Compute Unified Device Architecture)是NVIDIA推出的异构计算平台,PyTorch中有专门的模块torch.cuda来设置和运行CUDA相关操作.本 ...
- ar9485 win10 笔记本电脑 无线网间歇性掉线
问题 新安装了系统,刚开始上网正常,下载东西或者待机一段时间后掉线了. wifi都能搜到,就是连不上,重启电脑可以解决,但是每次重启很麻烦,必须找到治本的方法. 排除问题 1.手机连接没有问题,排除 ...