Codeforces Round #538 (Div. 2) (A-E题解)
Codeforces Round #538 (Div. 2)
题目链接:https://codeforces.com/contest/1114
A. Got Any Grapes?
题意:
有三个人,有三种食物,食物对应的数量为a,b,c,三个人需要的食物量分别为x,y,z。
现在第一个人只吃第一种食物,第二个人只吃前两种食物,第三个人都要吃。问准备的食物数量是否能够满足这三个人。
题解:
简单模拟一下就行了。
代码如下:
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int x,y,z;
int a,b,c; int main(){
cin>>x>>y>>z>>a>>b>>c;
if(a>=x && a-x+b>=y && a+b+c-x-y>=z) cout<<"YES";
else cout<<"NO";
return ;
}
B. Yet Another Array Partitioning Task
题意:
给出n个数,现在要将其划分为k个区间,要求从每个区间选出的m个最大值的和最大。问最大值以及怎样划分区间。
题解:
可以发现,最终选出来的数就是最大的那些数。
所以我们排下序,并且记录一下数原来的位置,贪心地选顺便标记一下位置就行了。
代码如下:
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 2e5+;
ll a[N];
int n,m,k;
int vis[N];
struct node{
ll v,pos;
bool operator < (const node &A)const{
return v<A.v;
}
}b[N];
int main(){
scanf("%d%d%d",&n,&m,&k);
for(int i=;i<=n;i++){
scanf("%I64d",&a[i]);
b[i]=node{a[i],i};
}
sort(b+,b+n+);
ll ans = ;
for(int i=n;i>=n-m*k+;i--){
ans+=b[i].v;
vis[b[i].pos]=;
}
int cnt = ;
int num=;
cout<<ans<<endl;
for(int i=;i<=n;i++){
if(vis[i]){
cnt++;
if(cnt==m){
num++;
if(num==k) break ;
cout<<i<<" ";
cnt=;
}
}
}
return ;
}
C. Trailing Loves (or L'oeufs?)
题意:
给出n和b,问n!在b进制下,后面有多少个连续的0?
其中1<=n<=1018,2<=b<=1012。
题解:
可以通过类比在十进制下的情况来进行思考。
根据唯一分解定理,假设b可以分解为p1q1 * p2q2 *...* pmqm,其中p1,p2...pm为质数。
同时,n!也可以分解成相应的形式:K * p1r1 * p2r2 *...* pmrm,K为一个常数,这个常数可能很大,但没必要去管。
那么,最终的答案即为min{ri/pi},这个类比一下十进制就可以发现了。
这里面{pm},{qm}都比较好求,可以不用把素数给筛出来。主要是{rm},这里的求法比较巧妙,详见代码吧:
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n,b; int main(){
cin>>n>>b;
ll ans = 2e18;
for(ll i=;i*i<=b;i++){
ll a=,c=;
if(b%i!=) continue ;
while(b%i==) b/=i,c++;
ll m=n;
while(m) a+=m/i,m/=i;
ans=min(ans,a/c);
}
if(b>){
ll a=;
while(n) a+=n/b,n/=b;
ans=min(ans,a);
}
cout<<ans<<endl;
return ;
}
D. Flood Fill
题意:
给出n个数,现在你可以任选一个数作为起点,然后每次将起点所在的连通块(连续的数相等即可成为连通块)变为一个数。问最少需要多少次操作,能让所有的数相等。
题解:
考虑动态规划,可以发现,每次的变化,要么连通块中的数都变为与左边相等,要么都变为与右边相等。
定义状态dp[l][r][0/1]:区间[l,r]内的数都与c[l/r]相等,我们可以不用管起点在哪,直接类似于区间dp那样进行转移就行了。
代码如下:
#include <bits/stdc++.h>
#define INF 0x3f3f3f3f
using namespace std;
typedef long long ll;
const int N = ;
int n;
int c[N];
int dp[N][N][];
int main(){
cin>>n;
for(int i=;i<=n;i++) scanf("%d",&c[i]);
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
dp[i][j][]=dp[i][j][]=(i==j)?:INF;
}
}
for(int k=;k<=n;k++){
for(int i=;i<=n;i++){
int j=i+k-;
if(j>n) break ;
if(i<n){
dp[i][j][]=min(dp[i][j][],dp[i+][j][]+(c[i]!=c[i+]));
dp[i][j][]=min(dp[i][j][],dp[i+][j][]+(c[i]!=c[j]));
}
if(j>){
dp[i][j][]=min(dp[i][j][],dp[i][j-][]+(c[j]!=c[i]));
dp[i][j][]=min(dp[i][j][],dp[i][j-][]+(c[j]!=c[j-]));
}
}
}
int ans=min(dp[][n][],dp[][n][]);
cout<<ans;
return ;
}
E. Arithmetic Progression
题意:
交互题。题目要你猜出一个等差数列的首项以及公差,题目中会给出一共有多少项。
然后你有两种询问:1."> x",即询问数列中是否有大于x的数,最后会返回0或1;2.“? i”,询问第i个位置的数,会返回第i个位置的数。
要求你用最多60次询问机会,得到等差数列的首项以及公差。
题解:
这也是一个比较有意思的交互题,我想的是直接二分求出数列中的最大最小值,但最后发现只能求出数列中的最大值。
做法就是先用不超过30次的询问机会找出最大值是什么,然后用剩余的机会随机询问数列中的某些项的值为多少(新技能mt19937 get)。
最后将得到的项排序,求出两两之间的差值的gcd就行了。因为这里差值都为公差d的倍数。
做法就是上面这样...但是这并不能保证100%正确,可能会存在差错,但几率会非常小,具体证明我也不会...
代码如下:
#include <bits/stdc++.h>
#define INF 0x3f3f3f3f;
using namespace std;
typedef long long ll;
const int N = 1e6+;
int n,Max,cnt,d;
mt19937 rnd(time(NULL));
int query1(int x){
printf("> %d\n",x);
fflush(stdout);
int ans;
scanf("%d",&ans);
return ans ;
}
void getMAX(){
int l=,r=1e9+,mid;
while(l<r){
mid=l+r>>;
cnt++;
if(query1(mid)) l=mid+;
else r=mid;
}
Max=l;
}
int query2(int pos){
printf("? %d\n",pos);fflush(stdout);
int ans;
scanf("%d",&ans);
return ans ;
}
void getD(){
vector <int> lst;
while(){
++cnt;
if(cnt>)break;
int now=query2(rnd()%n+);
lst.push_back(now);
}
sort(lst.begin(),lst.end());
lst.erase(unique(lst.begin(),lst.end()),lst.end());
if(lst.back()!=Max) lst.push_back(Max);
d=lst[]-lst[];
for(int i=;i<lst.size();i++){
d=__gcd(lst[i]-lst[i-],d);
}
}
int main(){
scanf("%d",&n);
getMAX();
getD();
int Min = Max-(n-)*d;
printf("! %d %d",Min,d);
return ;
}
Codeforces Round #538 (Div. 2) (A-E题解)的更多相关文章
- Codeforces Round #538 (Div. 2) (CF1114)
Codeforces Round #538 (Div. 2) (CF1114) 今天昨天晚上的cf打的非常惨(仅代表淮中最低水平 先是一路缓慢地才A掉B,C,然后就开始杠D.于是写出了一个O( ...
- Codeforces Round #612 (Div. 2) 前四题题解
这场比赛的出题人挺有意思,全部magic成了青色. 还有题目中的图片特别有趣. 晚上没打,开virtual contest打的,就会前三道,我太菜了. 最后看着题解补了第四道. 比赛传送门 A. An ...
- Codeforces Round #198 (Div. 2)A,B题解
Codeforces Round #198 (Div. 2) 昨天看到奋斗群的群赛,好奇的去做了一下, 大概花了3个小时Ak,我大概可以退役了吧 那下面来稍微总结一下 A. The Wall Iahu ...
- Codeforces Round #672 (Div. 2) A - C1题解
[Codeforces Round #672 (Div. 2) A - C1 ] 题目链接# A. Cubes Sorting 思路: " If Wheatley needs more th ...
- Codeforces Round #538 (Div. 2)
目录 Codeforces 1114 A.Got Any Grapes? B.Yet Another Array Partitioning Task C.Trailing Loves (or L'oe ...
- Codeforces Round #538 (Div. 2) F 欧拉函数 + 区间修改线段树
https://codeforces.com/contest/1114/problem/F 欧拉函数 + 区间更新线段树 题意 对一个序列(n<=4e5,a[i]<=300)两种操作: 1 ...
- Codeforces Round #538 (Div. 2) E 随机数生成
https://codeforces.com/contest/1114/problem/E 题意 交互题,需要去猜一个乱序的等差数列的首项和公差,你能问两种问题 1. 数列中有没有数比x大 2. 数列 ...
- Codeforces Round #538 (Div. 2) C 数论 + 求b进制后缀零
https://codeforces.com/contest/1114/problem/C 题意 给你一个数n(<=1e8),要你求出n!在b进制下的后缀零个数(b<=1e12) 题解 a ...
- Codeforces Round #614 (Div. 2) A-E简要题解
链接:https://codeforces.com/contest/1293 A. ConneR and the A.R.C. Markland-N 题意:略 思路:上下枚举1000次扫一遍,比较一下 ...
随机推荐
- logger模块的使用
logging模块 下面是logger模块的配置文件,在写程序需要记录日志可以直接拿过来用,但是要经过相应配置的一些修改. 对于如何使用,在我上一篇随笔<ATM程序规范练习>中的记录日志的 ...
- HyperLedger Fabric 1.4 区块链应用场景(3.1)
比特币是区块链应用最早的场景,随着比特币安全稳定运行多年以后,数字货币的场景应用遍地开花,各种山寨币泛滥,通过ICO(Initial Coin Offering 首次币发行)就能融到大量资金,上市后的 ...
- CUBLAS基础实验
一.概述 最近在试图进行cuda并行编程,目标是编写一段矩阵计算代码,将计算结果存储进入GPU的缓冲区当中,并在达到某些要求后强制刷新缓冲区,取得计算结果. 但是考虑时间紧任务重的状况和实际的性能要求 ...
- 为什么我要放弃javaScript数据结构与算法(第一章)—— JavaScript简介
数据结构与算法一直是我算比较薄弱的地方,希望通过阅读<javaScript数据结构与算法>可以有所改变,我相信接下来的记录不单单对于我自己有帮助,也可以帮助到一些这方面的小白,接下来让我们 ...
- Hibernate-ORM:12.Hibernate中的多对多关联关系
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 本篇博客将讲述Hibernate中的多对多关联关系的操作,准备的篇幅较少,望海涵 一,讲述多对多 多对多的关联 ...
- luogu2387 [NOI2014]魔法森林
这题和水管局长很像,枚举 \(a\) 的边然后维护关于 \(b\) 的最小生成树就可以了. 1A呐>_< #include <algorithm> #include <i ...
- Word 2013 无法撤销操作的错误
来自 <http://delxu.blog.51cto.com/975660/1409139> 关闭正在运行的所有程序. 按Win-R,在运行框中键入regedit,然后单击“确定”. 在 ...
- python发起请求提示UnicodeEncodeError
具体错误: UnicodeEncodeError: 'latin-1' codec can't encode characters in position 73-74: Body ('测试') is ...
- 第一篇 Postman的初级使用之设置环境快速切换生成环境与测试环境
POSTMAN是有谷歌的开源工具,在开发调试.测试执行过程中使用频率非常广泛,本文将记录一些postman在测试中常见的一些配置和使用方法 一.基本的页面区域 略,很简单,大家都会看,再有,学习下面的 ...
- linux下 su 与 su - 的区别和使用
Linux下su与su -命令的区别 在启动服务器ntpd服务时遇到一个问题 使用 su root 切换到root用户后,不可以使用service命令: 使用 su - 后,就可以使用servic ...