【Codeforces】Round #488 (Div. 2) 总结
【Codeforces】Round #488 (Div. 2) 总结
比较僵硬的一场,还是手速不够,但是作为正式成为竞赛生的第一场比赛还是比较圆满的,起码没有FST,A掉ABCD,总排82,怒涨rating两百
A:Fingerprints
A题,就在第一个串中查找第二个串中的数字,最气的是一开始没编译直接交CE了,噗
#include<iostream>
#include<cstdio>
using namespace std;
int read(){
int ans=0,w=1;char c=getchar();
while(!isdigit(c)&&c!='-')c=getchar();
if(c=='-')c=getchar(),w=-1;
while(isdigit(c))ans=ans*10+c-'0',c=getchar();
return ans*w;
}
#define N 20
int a[N],b[N];
int main(){
int n=read(),m=read();
for(int i=1;i<=n;i++)a[i]=read();
for(int j=1;j<=m;j++)b[j]=read();
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++)
if(a[i]==b[j]){
cout<<a[i]<<" ";
break;
}
}
return 0;
}
B:Knights of a Polygonal Table
B题,照样是手速题,按照能力值排一个序,然后可以用小根堆维护一下当前可以获得的最大价值,然后记录一下就好
#include<bits/stdc++.h>
using namespace std;
#define LL long long
LL read(){
LL ans=0,w=1;char c=getchar();
while(!isdigit(c)&&c!='-')c=getchar();
if(c=='-')c=getchar(),w=-1;
while(isdigit(c))ans=ans*10+c-'0',c=getchar();
return ans*w;
}
#define N 100010
struct Node{
LL p,c,id,ans;
}a[N];
LL n,k,ans[N];
priority_queue<LL,vector<LL>,greater<LL> > q;
bool cmp(Node a,Node b){
return a.p<b.p;
}
bool cmp2(Node a,Node b){
return a.id<b.id;
}
int main(){
LL sum=0;
n=read();k=read();
for(LL i=1;i<=n;i++)a[i].p=read();
for(LL i=1;i<=n;i++)a[i].c=read(),a[i].id=i;
sort(a+1,a+n+1,cmp);
for(LL i=1;i<=min(k+1,n);i++){
a[i].ans=a[i-1].ans+a[i].c;
q.push(a[i].c);
sum+=a[i].c;
}
for(LL i=k+2;i<=n;i++){
LL top=q.top();q.pop();
sum-=top;
q.push(a[i].c);
sum+=a[i].c;
a[i].ans=sum;
}
sort(a+1,a+n+1,cmp2);
for(LL i=1;i<=n;i++)
printf("%I64d ",a[i].ans);
return 0;
}
C:Two Squares
就是给你两个正方形,判断有没有相交
我把这种题叫做不用脑子却死一片
final test的时候有一大堆人这题fst了。。诶
把握好代码的细节,然后写几个特判就好了
#include<bits/stdc++.h>
using namespace std;
struct Node{
int x,y;
}a[5],b[5];
bool cmp(Node a,Node b){
if(a.x==b.x)return a.y<b.y;
return a.x<b.x;
}
int main(){
for(int i=1;i<=4;i++)scanf("%d%d",&a[i].x,&a[i].y);
for(int i=1;i<=4;i++)scanf("%d%d",&b[i].x,&b[i].y);
sort(a+1,a+5,cmp);
sort(b+1,b+5,cmp);
int tmp=0;
if(b[4].x<a[1].x)tmp=1;
if(b[2].y>a[2].y)tmp=1;
if(b[3].y<a[1].y)tmp=1;
if(b[1].x>a[3].x)tmp=1;
if(tmp){
printf("NO");
return 0;
}
//zuoshang
if(b[1].x<a[2].x&&b[3].y>a[2].y){
int t=b[2].y-b[2].x;
if(t+a[2].x>a[2].y)tmp=1;
}
//zuoxia
if(b[1].x<a[1].x&&b[2].y<a[1].y){
int t=b[3].x+b[3].y;
if(t-a[1].x<a[1].y)tmp=1;
}
//youshang
if(b[3].y>a[4].y&&b[4].x>a[4].x){
int t=b[1].x+b[1].y;
if(t-a[4].x>a[4].y)tmp=1;
}
//youxia
if(b[2].y<a[3].y&&b[4].x>a[3].x){
int t=b[3].y-b[3].x;
if(t+a[3].x<a[3].y)tmp=1;
}
if(tmp){
printf("NO");
return 0;
}
printf("YES");
return 0;
}
D:Open Communication
身为一个蒟蒻这种题我还是少碰的好,题意很毒瘤,然后我就用非常不正常的做法A了,我都不知道我是怎么A的。
大概是有两个无聊的人,他们互相传递数字对,让你确定他们的秘密数字是什么,然后秘密数字是:对于两个元素不完全相等数对,其中一个相等的元素
然后可以确定输出那个数,你不能确定但那两个人可以确定输出0,你和其中一人都不能确定输出-1
然后我就记录一下在每个人的信息里可能匹配的和全局可能匹配的,加一堆特判就好了,反正是乱搞做法
#include<bits/stdc++.h>
using namespace std;
#define N 30
struct Pai{
int a,b;
}x[N],y[N];
int n,m,pic[N];
int vis1[N][N],vis2[N][N];
int tmp1[N],tmp2[N];
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++)cin>>x[i].a>>x[i].b;
for(int i=1;i<=m;i++)cin>>y[i].a>>y[i].b;
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++){
if(x[i].a==y[j].a&&x[i].b==y[j].b)continue;
if(x[i].a==y[j].b&&x[i].b==y[j].a)continue;
if(x[i].a==y[j].a||x[i].a==y[j].b)pic[x[i].a]=1,vis1[i][x[i].a]=1,vis2[j][x[i].a]=1;
if(x[i].b==y[j].a||x[i].b==y[j].b)pic[x[i].b]=1,vis1[i][x[i].b]=1,vis2[j][x[i].b]=1;
}
for(int i=1;i<=n;i++)
for(int j=1;j<=9;j++)tmp1[i]+=vis1[i][j];
for(int i=1;i<=m;i++)
for(int j=1;j<=9;j++)tmp2[i]+=vis2[i][j];
int siz=0,tip;
for(int i=1;i<=9;i++){
siz+=pic[i];
if(pic[i])tip=i;
}
if(siz==1){
cout<<tip;
return 0;
}
if(!siz){
cout<<"-1";
return 0;
}
for(int i=1;i<=n;i++){
if(tmp1[i]>1){
cout<<"-1";
return 0;
}
}
for(int i=1;i<=m;i++){
if(tmp2[i]>1){
cout<<"-1";
return 0;
}
}
cout<<"0";
return 0;
}
E:Careful Maneuvering
F:Compute Power
【Codeforces】Round #488 (Div. 2) 总结的更多相关文章
- Codeforces Round #488 Div. 1
A:枚举每个点判断是否同时在两个正方形中即可. #include<iostream> #include<cstdio> #include<cmath> #inclu ...
- [Codeforces Round#488]Div.2
总结 这是我无聊透顶肝到三点半的一场 cf ,结果还真够无聊的 这套题涵盖了英语题,语文题,模拟题.注重考查了选手的英语素养能力,语文阅读能力和精湛的模拟和枚举能力.是不可多得的一套好题. 没什么单独 ...
- Codeforces Round #366 (Div. 2) ABC
Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...
- Codeforces Round #354 (Div. 2) ABCD
Codeforces Round #354 (Div. 2) Problems # Name A Nicholas and Permutation standard input/out ...
- Codeforces Round #368 (Div. 2)
直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- Codeforces Round #279 (Div. 2) ABCDE
Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems # Name A Team Olympiad standard input/outpu ...
- Codeforces Round #262 (Div. 2) 1003
Codeforces Round #262 (Div. 2) 1003 C. Present time limit per test 2 seconds memory limit per test 2 ...
- Codeforces Round #262 (Div. 2) 1004
Codeforces Round #262 (Div. 2) 1004 D. Little Victor and Set time limit per test 1 second memory lim ...
随机推荐
- angular js实现开关效果
功能:实现点击排序,再点击排倒序. 实现方法如下 方法一:定义变量实现点击切换true或false,代码为: $scope.lidata = [ {"name ...
- MySQL行锁、间隙锁、Next-Key锁
InnoDB是一个支持行锁的存储引擎,它有三种行锁的算法: Record Lock:行锁,单个行记录上的锁. Gap Lock:间隙锁,锁定一个范围,但不包括记录本身.GAP锁的目的,是为了防止幻读. ...
- pg_ctl -- 启动、停止、重启 PostgreSQL
pg_ctl 名称 pg_ctl -- 启动.停止.重启 PostgreSQL 语法 pg_ctl start [-w] [-s] [-D datadir] [-l filename] [-o opt ...
- 从源码角度分析 Kotlin by lazy 的实现
by lazy 的作用 延迟属性(lazy properties) 是 Kotlin 标准库中的标准委托之一,可以通过 by lazy 来实现. 其中,lazy() 是一个函数,可以接受一个 Lamb ...
- sql数据类型转换函数
1.CAST()CAST (<expression> AS <data_ type>[ length ]) 2.CONVERT()CONVERT (<data_ type ...
- [postgresql]ROWS is not applicable when function does not return a set问题解决
需要把程序结尾的ROWS 1000去掉,提示如果函数不是返回一个数据集的情况下ROWS是不适用的: CREATE OR REPLACE FUNCTION public.function( eigyou ...
- 【程序员笔试面试必会——排序②】Python实现 计数排序、基数排序
一.计数排序 概要: 时间复杂度O(n),空间复杂度O(k),k是输入序列的值的范围(最大值-最小值),是稳定的.计数排序一般用于已知输入值的范围相对较小,比如给公司员工的身高体重信息排序. 思路: ...
- 玲珑oj 1128 RMQ模板
1128 - 咸鱼拷问 Time Limit:3s Memory Limit:128MByte Submissions:380Solved:118 DESCRIPTION 给你两个序列A,B.每个序列 ...
- asp.net服务器上无法发送邮件的问题
前几天为开发的网站做了个发送邮件的功能,但是部署到服务器上无法发送邮件,提示由于目标机器积极拒绝,无法连接.在网上找到了一个解决办法 如果安装了McAfee杀毒软件(按照“手工安装方法”安装),首先需 ...
- Linux命令nohup+screen 转
如果想在关闭ssh连接后刚才启动的程序继续运行怎么办,可以使用nohup.但是如果要求第二天来的时候,一开ssh,还能查看到昨天运行的程序的状态,然后继续工作,这时nohup是不行了,需要使用scre ...