Codeforces Round #620 (Div. 2)

A. Two Rabbits

题意

两只兔子相向而跳,一只一次跳距离a,另一只一次跳距离b,每次同时跳,问是否可能到同一位置

题解

每次跳相对距离减少Δ=(a+b)\Delta=(a+b)Δ=(a+b),如果总距离是Δ\DeltaΔ的倍数,就证明可以到同一位置

代码

#include<iostream>
#include<cstdio>
using namespace std; int main()
{ long N,x,y,a,b;
scanf("%ld",&N);
while(N--){
scanf("%ld%ld%ld%ld",&x,&y,&a,&b);
if((y-x)%(a+b)==0)
printf("%ld\n",(y-x)/(a+b));
else
printf("-1\n");
}
return 0;
}

B. Longest Palindrome

题意

给定n个字符串,选择其中的若干个重新排列,找出能得到的最长回文串

题解

将每个串记录下来,如果一个串颠倒后和另一个串相等,就证明可取,放在答案串的两边;如果一个串本身就是回文串,就可以放在答案串的中间

代码

#include<iostream>
#include<cstdio>
#include<set>
using namespace std; set<string>st; int main()
{ long n,m,i,j;
string s,s1,ans="",ans_mid;
bool t=false;
scanf("%ld%ld",&n,&m);
for(i=1;i<=n;i++){
cin>>s;
s1="";
for(j=0;j<m;j++)
s1=s[j]+s1;
if(s==s1){
if(!t){
t=true;
ans_mid=s;
}
}
else if(st.find(s1)!=st.end())
ans=s+ans+s1;
st.insert(s);
}
if(t)
ans.insert(ans.length()/2,ans_mid);
cout<<ans.length()<<endl<<ans<<endl;
return 0;
}

C. Air Conditioner

题意

店里的空调可开可关,开着每分钟温度可以上升或者下降1度,每位顾客有个满意温度范围,已知所有顾客的访问时间和温度范围,问是否可能做到满足所有顾客

题解

记录下能调到的最大最小温度,如果跟顾客的满意温度有交集,就把温度范围变成交集的范围,否则就无法满足

代码

#include<cstdio>
#define max(a,b) (((a)>(b))?(a):(b))
#define min(a,b) (((a)<(b))?(a):(b))
#define def 110 long t[def],x[def],y[def]; int main()
{ long N,n,m,l,r,i;
bool ans;
scanf("%ld",&N);
while(N--){
scanf("%ld%ld",&n,&m);
l=r=m;
ans=true;
for(i=1;i<=n;i++){
scanf("%ld%ld%ld",&t[i],&x[i],&y[i]);
l-=t[i]-t[i-1];
r+=t[i]-t[i-1];
if(l<=y[i]&&r>=x[i]){
l=max(l,x[i]);
r=min(r,y[i]);
}else
ans=false;
}
if(ans)
printf("YES\n");
else
printf("NO\n");
}
return 0;
}

D. Shortest and Longest LIS

题意

给定数列的相邻数之间的大小关系,求出满足给定的大小关系的所有数列中,最长上升子序列最大和最小的两个数列

题解

最长上升子序列一定出现在所有<的左右,那么只用构造<左边的数(右边的不能构造,会导致可能不能满足后面可能存在的>),剩下的按大小关系递增或递减填充即可

代码

#include<iostream>
#include<cstdio>
#define min(a,b) (((a)<(b))?(a):(b))
#define def 200010
using namespace std; long l[def],r[def],ans[2][def]; int main()
{ long N,n,now,i,minn,j,q,k;
string s;
scanf("%ld",&N);
while(N--){
cin>>n>>s;
s+="<";
now=1;
for(i=0;i<n;i++)//正向从小到大填充 <
if(s[i]=='<')
ans[1][i]=now++;
q=now;
for(i=0;i<n;i++)//正向从小到大填充 >
if(s[i]=='<')
for(j=i-1;j>=0&&s[j]=='>';j--)
ans[1][j]=now++; now=q-1;
for(i=0;i<n;i++)//反向从小到大填充 <
if(s[i]=='<'){
if(s[i+1]!='<')
ans[0][i]=now--;
else{
for(j=i+1;s[j]=='<'&&j<n;j++);
j--;
for(k=j;k>=i;k--)
ans[0][k]=now--;
i=j;
}
}
now=q;
for(i=n-1;i>=0;i--)//反向从小到大填充 >
if(s[i]=='<')
for(j=i-1;j>=0&&s[j]=='>';j--)
ans[0][j]=now++; for(i=0;i<n;i++)
printf("%ld ",ans[0][i]);
printf("\n");
for(i=0;i<n;i++)
printf("%ld ",ans[1][i]);
printf("\n");
}
return 0;
}

E. 1-Trees and Queries

题意

给定一棵树,每次询问加一条从x到y的边,问是否可能满足从a点到b点的路径长度恰好等于k(可重复走一条边)

题解

因为可以重复走,所以可以反复横跳,这里长度为偶数,所以只需要判断走或者不走新的一条边后,剩下的需求长度是否为偶数即可。

ps:树上距离可以用深度和lca快速计算,新边长度为1,所以不需要真正把边加上去

代码

#include<cstdio>
#include<cstring>
#include<vector>
#define def 100010
using namespace std; vector<long>mp[def];
long dep[def],fa[def][20]; inline void swap(long &a,long &b)
{ long tmp=a;
a=b;
b=tmp;
} void dfs(long now,long d)
{ long i;
dep[now]=d;
for(i=0;(1<<i)<=def;i++)
fa[now][i+1]=fa[fa[now][i]][i];
for(auto next:mp[now])
if(!dep[next]){
fa[next][0]=now;
dfs(next,d+1);
}
} long lca(long x,long y)
{ long i;
if(dep[x]<dep[y])
swap(x,y);
for(i=19;i>=0;i--)
if(dep[fa[x][i]]>dep[y])
x=fa[x][i];
if(dep[x]!=dep[y])
x=fa[x][0];
for(i=19;i>=0;i--)
if(fa[x][i]!=fa[y][i]){
x=fa[x][i];
y=fa[y][i];
}
return (x==y)?x:fa[x][0];
} long calc(long x,long y)
{
return dep[x]+dep[y]-dep[lca(x,y)]*2;
} bool check(long q,long k)
{
return q<=k&&(k-q)%2==0;
} int main()
{ long n,i,x,y,a,b,k,m;
scanf("%ld",&n);
for(i=1;i<n;i++){
scanf("%ld%ld",&x,&y);
mp[x].push_back(y);
mp[y].push_back(x);
}
dfs(1,1);
scanf("%ld",&m);
for(i=1;i<=m;i++){
scanf("%ld%ld%ld%ld%ld",&x,&y,&a,&b,&k);
if(check(calc(a,b),k)||
check(calc(a,x)+calc(b,y)+1,k)||
check(calc(a,y)+calc(b,x)+1,k))
printf("YES\n");
else
printf("NO\n");
}
return 0;
}

Codeforces Round #620 (Div. 2)的更多相关文章

  1. Codeforces Round #620 (Div. 2) A. Two Rabbits

    Being tired of participating in too many Codeforces rounds, Gildong decided to take some rest in a p ...

  2. Codeforces Round #620 (Div. 2)E LCA

    题:https://codeforces.com/contest/1304/problem/E 题意:给定一颗树,边权为1,m次询问,每次询问给定x,y,a,b,k,问能否在原树上添加x到y的边,a到 ...

  3. Codeforces Round #620 (Div. 2)D dilworld定理

    题:https://codeforces.com/contest/1304/problem/D 题意:给定长度为n-1的只含’>'和‘<’的字符串,让你构造出俩个排列,俩个排列相邻的数字之 ...

  4. Codeforces Round #620 (Div. 2) D

    构造一个排列,要求相邻之间的数满足给定的大小关系,然后构造出两个序列,一个序列是所有可能的序列中LIS最长的,一个所有可能的序列中LIS最短的 最短的构造方法:我们考虑所有单调递增的部分,可以发现要让 ...

  5. Codeforces Round #620 (Div. 2) A-F代码 (暂无记录题解)

    A. Two Rabbits (手速题) #include<bits/stdc++.h> using namespace std; typedef long long ll; int ma ...

  6. Codeforces Round #620 (Div. 2)E(LCA求树上两点最短距离)

    LCA求树上两点最短距离,如果a,b之间距离小于等于k并且奇偶性与k相同显然YES:或者可以从a先走到x再走到y再走到b,并且a,x之间距离加b,y之间距离+1小于等于k并且奇偶性与k相同也输出YES ...

  7. Codeforces Round #620 (Div. 2)D(LIS,构造)

    #define HAVE_STRUCT_TIMESPEC #include<bits/stdc++.h> using namespace std; ]; ]; int main(){ io ...

  8. Codeforces Round #620 (Div. 2) E

    LCA的倍增 模板: ], depth[maxn]; int dist[maxn],head[maxn]; void add(int u,int v,int dist0){ a[tot].next=h ...

  9. Codeforces Round #620 (Div. 2) C. Air Conditioner

    Gildong owns a bulgogi restaurant. The restaurant has a lot of customers, so many of them like to ma ...

随机推荐

  1. 提高线程数,解决redis超时问题

    根据压测结果做出的修改历史: 第一步:只针对maxWorkerThreads.maxIoThreads和minWorkerThreads做了修改<processModel autoConfig= ...

  2. 谁能率先挖掘出5G金矿?

    现在,消费者已经习惯4G的存在,它好像另外的一个太阳,点亮了夜生活,也丰富了白天的生活:随时随地的直播.视频通话.移动支付.嘀嘀打车等等,这些都因4G网络和智能手机而快速发展,帮助消费者清理碎片时间之 ...

  3. 系统学习 javaweb2----HTML语言2

    感想:学习javaweb之路,任重而道远. 学习笔记: 5.表格标签 5.1<table></table> 表格标签,用于效果中定义一个表格 5.2<tr>< ...

  4. RHCE考试(Linux7)

    博主本人平和谦逊,热爱学习,读者阅读过程中发现错误的地方,请帮忙指出,感激不尽 一.环境模拟 * server0.example.com :172.25.0.11 * desktop0.example ...

  5. 非参数检验|Sign test|Wilcoxon signed rank test|Wilcoxon rank sum test|Bootstrapping

    非参数检验条件没有参数,因此就没有分布,利用数据等级之间的差距,依次赋值之后再用参数方法测试.将连续型变量转化为离散型变量,即顺序变量.与参数检验相比,正态分布较弱(p值有可能不显著,浪费信息,比如最 ...

  6. Oracle 10G 服务端的升级

    第一步:备份 rman target / backup full database plus archivelog; 第二步:升级 解压升级包到soft目录下,修改所有者 chown -R oracl ...

  7. jquery.Table实现的翻页功能比较完整漂亮,本想扩展个模版DIV

    jquery.dataTable实现的翻页功能比较完整漂亮,本想提取其的翻页部分,再结合模版DIV,bootstrop实现聊天记息的展示. jquery.Table 与table结合的较紧,不能在很下 ...

  8. HTML5 file API加canvas实现图片前端JS压缩并上传

    一.图片上传前端压缩的现实意义 对于大尺寸图片的上传,在前端进行压缩除了省流量外,最大的意义是极大的提高了用户体验. 这种体验包括两方面: 由于上传图片尺寸比较小,因此上传速度会比较快,交互会更加流畅 ...

  9. pytorch的visdom启动不了、蓝屏

    pytorch的visdom启动不了.蓝屏 问题描述:我是在ubuntu16.04上用python3.5安装的visdom.可是启动是蓝屏:在网上找了很久的解决方案:有三篇博文: https://bl ...

  10. Tozan and Gezan(x*y<a*b)

    E - Tozan and Gezan Time limit : 2sec / Memory limit : 256MB Score : 700 points Problem Statement Yo ...