AtCoder Beginner Contest 172 题解
AtCoder Beginner Contest 172 题解
A - Calc
程序如下(真的有人需要嘛):
#include<bits/stdc++.h>
using namespace std;
int main(){
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
int a;
cin>>a;
cout<<a+a*a+a*a*a<<endl;
return 0;
}
B - Minor Change
程序如下(应该没人需要吧):
#include<bits/stdc++.h>
using namespace std;
string s,t;
int main(){
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
cin>>s>>t;
int ans=0;
for(int i=0;i<s.size();i++)ans+=s[i]!=t[i];
cout<<ans<<endl;
return 0;
}
C - Tsundoku
感性地理解,你在A桌上看的书越多,你在B桌上看的书越少。也就是说,你在A桌上每多看一本书,你在B桌上就要放下一些书。
维护A、B桌看的书的本数。从小到大枚举A桌看的书的本数,B桌看的书的本数就会递减。这个就是传说中的two pointers,然后程序就好写了。
程序如下:
#include<bits/stdc++.h>
using namespace std;
int n,m,k;
int a[200005],b[200005];
int main(){
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
cin>>n>>m>>k;
for(int i=1;i<=n;i++){
cin>>a[i];
}
long long tot=0;
for(int i=1;i<=m;i++){
cin>>b[i];
tot+=b[i];
}
int ans=0;
for(int ia=0,ib=m;ia<=n;ia++){
tot+=a[ia];
while(tot>k&&ib>0)tot-=b[ib--];
if(tot>k)break;
ans=max(ans,ia+ib);
}
cout<<ans<<endl;
return 0;
}
D - Sum of Divisors
正着想,从\(1\)到\(N\)枚举,求出一个数的质因数个数然后乘以它本身未尝不可,但是反着来有更简单的实现方法。
对于一个数,它是它倍数的因数,所以我们从\(1\)到\(N\)枚举一个数,加上它的所有倍数的和就可以算出答案了。
程序如下:
#include<bits/stdc++.h>
using namespace std;
long long ans;
int n;
int main(){
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
cin>>n;
for(int i=1;i<=n;i++){
for(int j=i;j<=n;j+=i){
ans+=j;
}
}
cout<<ans<<endl;
return 0;
}
E - NEQ
(根据咱的习惯把题目里的\(M\)、\(N\)都写成了小写的说)
首先不考虑\(B\),只考虑\(A\)。容易看出所有可能的\(A\)有\(m^\underline n\)种。
然后对于每一种\(A\),我们考虑有多少种不合法的\(B\)的情况。
假设有\(k\)个不合法的位置,那么其余合法的位置有\(n-k\)个,可以放的数字有\(m-k\)个,那么其余合法的位置就有\((m-k)^\underline{n-k}\)种可能的摆放方法。然后根据容斥原理可以得到如下公式,表示对于每一种\(A\)有多少个合法的\(B\):
\]
结合之前对于\(A\)的可能种数的计算,本题答案如下:
\]
写成对于程序实现友好的形式:
\]
程序如下(但是不比上面的公式好懂):
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int mod=1e9+7;
inline ll qpow(ll a,ll n){
ll res=1;
while(n){
if(n&1)res=res*a%mod;
a=a*a%mod;
n>>=1;
}
return res;
}
int n,m;
ll ans,f[500005]={1},inv[500005]={1};
int main(){
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
for(int i=1;i<=5e5;i++){
f[i]=f[i-1]*i%mod;
inv[i]=qpow(f[i],mod-2);
}
cin>>n>>m;
for(int i=0;i<=n;i++){
ans=(ans+f[n]*inv[i]%mod*inv[n-i]%mod*((i&1)?-1:1)*f[m-i]%mod*inv[m-n]%mod)%mod;
}
for(int i=m-n+1;i<=m;i++)ans=ans*i%mod;
cout<<(ans+mod)%mod<<endl;
return 0;
}
F - Unfair Nim
位运算真的太难了qaq
首先在高桥(Takahashi)作弊前,这个题目是一个标准的Nim游戏,对于先手的青木(Aoki)来说,当且仅当\(A_1 \oplus A_2 \oplus \dots \oplus A_n = 0\)时,他一定输掉。否则就是青木的胜利。
那么我们需要通过这一次从第一堆转移到第二堆的操作来使得所有石头堆的异或和为\(0\),问题就可以转化为如下形式:
给你三个数\(A\),\(B\),\(C\)(\(A\)是\(A_1\),\(B\)是\(A_2\),\(C\)是\(A_3 \oplus A_4 \oplus \dots \oplus A_n\)),问你是否有两个整数\(a\),\(b\),使得\(1 \leq a \leq A\)且\(a + b = A + B\)且\(a \oplus b = C\)。如果有,输出最大的\(a\),否则输出
-1。
由于异或就是二进制下不带进位的加法,所以我们可以看出\(\frac {A + B - C} 2 = A \& B\)(此处特判\(A + B - C\)不能被\(2\)整除的情况)。这样我们定义\(D = \frac {A + B - C} 2\),感性的讲,这就是\(A\)和\(B\)两个数中二进制位同为\(1\)的部分。显然它不能是负数,同时不能比\(A\)大(毕竟你需要从\(A\)转移石子到\(B\),而不是反向转移)。其次,它不能和\(C\)有共同为\(1\)的二进制位,因为\(a\),\(b\)中的这些位最后异或起来后必定是\(0\),无法通过操作使得结果为\(1\)。
然后我们就可以贪心地想了,首先把\(D\)赋值给\(a\),然后从高位往低位枚举,假如\(C\)这一位是\(1\)同时\(a\)加上这一位不会比\(A\)大,那么就可以把\(a\)的这一位设成\(1\),最终可以得到最大的可能的\(a\)(特判最大的\(a\)是\(0\)的情况)。
程序非常好写赛时不会的人还有脸说:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main(){
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
int n;
cin>>n;
ll A,B,C=0;
cin>>A>>B;
for(int i=3;i<=n;i++){
ll tmp;
cin>>tmp;
C^=tmp;
}
ll D=A+B-C>>1;
if(A+B-C&1||D<0||D>A||D&C){
cout<<"-1\n";
return 0;
}
ll a=D;
for(int i=60;i>=0;i--){
if(C>>i&1&&D>>i&1^1&&(a|1ll<<i)<=A){
a|=1ll<<i;
}
}
if(a==0){
cout<<"-1\n";
return 0;
}
cout<<A-a<<endl;
return 0;
}
AtCoder Beginner Contest 172 题解的更多相关文章
- AtCoder Beginner Contest 154 题解
人生第一场 AtCoder,纪念一下 话说年后的 AtCoder 比赛怎么这么少啊(大雾 AtCoder Beginner Contest 154 题解 A - Remaining Balls We ...
- AtCoder Beginner Contest 153 题解
目录 AtCoder Beginner Contest 153 题解 A - Serval vs Monster 题意 做法 程序 B - Common Raccoon vs Monster 题意 做 ...
- AtCoder Beginner Contest 177 题解
AtCoder Beginner Contest 177 题解 目录 AtCoder Beginner Contest 177 题解 A - Don't be late B - Substring C ...
- AtCoder Beginner Contest 184 题解
AtCoder Beginner Contest 184 题解 目录 AtCoder Beginner Contest 184 题解 A - Determinant B - Quizzes C - S ...
- AtCoder Beginner Contest 173 题解
AtCoder Beginner Contest 173 题解 目录 AtCoder Beginner Contest 173 题解 A - Payment B - Judge Status Summ ...
- AtCoder Beginner Contest 169 题解
AtCoder Beginner Contest 169 题解 这场比赛比较简单,证明我没有咕咕咕的时候到了! A - Multiplication 1 没什么好说的,直接读入两个数输出乘积就好了. ...
- AtCoder Beginner Contest 148 题解
目录 AtCoder Beginner Contest 148 题解 前言 A - Round One 题意 做法 程序 B - Strings with the Same Length 题意 做法 ...
- AtCoder Beginner Contest 151 题解报告
总的来说,这次的题目比较水,然而菜菜的我并没有把所有题目都做完,话不多说,直接来干货: A:Next Alphabet 题目链接:https://atcoder.jp/contests/abc151/ ...
- AtCoder Beginner Contest 115 题解
题目链接:https://abc115.contest.atcoder.jp/ A Christmas Eve Eve Eve 题目: Time limit : 2sec / Memory limit ...
随机推荐
- Taro 3.4 beta 发布: 支持 Preact 为应用开辟更多体积空间
项目体积是困扰小程序开发者的一大问题,如果开发者使用 Taro React 进行开发,更是不得不引入接近 100K 的 React 相关依赖,这让项目体积变得更加捉襟见肘.因此,Taro v3.4 的 ...
- Electron快速入门之事件
const { app, BrowserWindow } = require('electron') function createWindow () { const win = new Brow ...
- 『学了就忘』Linux权限管理 — 56、不可改变位权限(chattr)
目录 1.命令格式 2.查看文件系统属性chattr权限 3.示例 文件系统属性chattr权限,也叫不可改变位权限,该权限没有风险,但是他能限制root用户. 1.命令格式 [root@localh ...
- CF1554E You
考虑到删点操作的实质是指认边的方向. 由于这是一棵树,所以有很好的性质. 我们完全可以以此从树叶开始,往上拓扑进行,按照对某个数的取膜的大小来进行操作. 由此可知,除了 \(1\) 以外,任意 \(2 ...
- 洛谷 P5518 - [MtOI2019]幽灵乐团 / 莫比乌斯反演基础练习题(莫比乌斯反演+整除分块)
洛谷题面传送门 一道究极恶心的毒瘤六合一题,式子推了我满满两面 A4 纸-- 首先我们可以将式子拆成: \[ans=\prod\limits_{i=1}^A\prod\limits_{j=1}^B\p ...
- Codeforces 788E - New task(线段树)
Codeforces 题目传送门 & 洛谷题目传送门 这是一道 *2900 的 D1E,而且被!我!自!己!搞!出!来!了! 虽然我承认它难度及摆放的位置异常异常虚高,并且就算我到了现场也不可 ...
- Topcoder 10748 - StringDecryption(dp)
题面传送门 神仙题. 首先这个两次加密略微有点棘手,咱们不妨先从一次加密的情况入手考虑这个问题.显然,一次加密等价于将加密过的序列划分成若干段,每一段都是 \(xd\) 的形式表示这一段中有 \(x\ ...
- Perl 语言入门6-9
---- 第6章 哈希----------- 简介 键值对.键和值都是任意标量,但键总是会被转换成字符串. 键唯一,值可重复. 应用场景:一组数据对应到另一组数据时. 如找出重复/唯一/交叉引用/查表 ...
- 【Meta】16s rRNA和16s rDNA的区别
在文章或宣传稿中经常看到两者滥用,实际上是不同的. 首先是各个字母的含义: 16S中的"S"是一个沉降系数,亦即反映生物大分子在离心场中向下沉降速度的一个指标,值越高,说明分子越大 ...
- 微信第三方平台获取component_verify_ticket
官方文档说明: 在公众号第三方平台创建审核通过后,微信服务器会向其"授权事件接收URL"每隔10分钟定时推送component_verify_ticket.第三方平台方在收到tic ...