Codeforces Round #395 (Div. 2)
今天自己模拟了一套题,只写出两道来,第三道时间到了过了几分钟才写出来,啊,太菜了。
A. Taymyr is calling you
水题,问你在z范围内 两个序列 n,2*n,3*n...... 和 m,2*m,3*m.....有多少个是一样的。
#include<bits/stdc++.h>
using namespace std;
int n,m,z;
int main()
{
cin>>n>>m>>z;
int gcd=__gcd(n,m);
int now=n*m/gcd;
int ans=;
int res=now;
while(res<=z)
{
ans++;
res+=now;
}
cout<<ans<<endl;
return ;
}
B. Timofey and cubes
题目大意:给你n个数,进行(n/2)次操作,每次操作将制定区间里的数交换,给你交换后的
让你求原来的。
思路:水题,奇偶讨论。
#include<bits/stdc++.h>
const int N=*1e5+;
using namespace std;
int a[N];
int n;
int main()
{
cin>>n;
for(int i=;i<=n;i++) scanf("%d",&a[i]);
int mid=n/;
int i=,j=n;
bool flag=true;
while(i<=j)
{
if(flag)
{
int t=a[i];
a[i]=a[j];
a[j]=t;
}
flag=!flag;
i++,j--;
}
for(int i=;i<=n;i++) printf("%d%c",a[i],i==n? '\n':' ');
return ;
}
C. Timofey and a tree
题目大意:给你一颗树,每个节点都有一个颜色,让你挑选一个节点当做整棵树的根,满足所有
子树中节点的颜色都是一样的。如果没有输出NO 否则输入YES 且输出选择的节点。
思路:刚开始的思路是我觉得这棵树中的颜色不能超过 3 种,后来一想这种想法好智障啊,明显
不对,后来枚举树根每个都dfs一下超时,结束后想我随便找一个点dfs找到两个相邻的颜色不同的
点,那么这两个点中间肯定有一个要当做树根的,否则不成立。这样只要dfs两次就行了。
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+;
vector<int> e[N];
int c[N],item1,item2,n;
map<int,bool> mp;
bool flag;
void dfs1(int u,int pre)
{
//printf("%d\n",u);
if(pre!=- && c[u]!=c[pre])
{
item1=u;
item2=pre;
return;
}
for(int i=;i<e[u].size();i++)
{
int to=e[u][i];
if(to!=pre) dfs1(to,u);
if(item1!=-) return;
}
}
void dfs(int u,int pre,int item)
{
// printf("%d %d %d**\n",u,pre,item);
if(pre!=item && pre!=- && c[u]!=c[pre])
{
flag=false;
return;
}
for(int i=;i<e[u].size();i++)
{
int to=e[u][i];
if(to!=pre) dfs(to,u,item);
if(!flag) return;
}
}
int main()
{
cin>>n;
for(int i=;i<n;i++)
{
int f,t;
scanf("%d%d",&f,&t);
e[f].push_back(t);
e[t].push_back(f);
}
int cnt=;
for(int i=;i<=n;i++) scanf("%d",&c[i]);
item1=-,item2=-;
dfs1(,-);
if(item1==-)
{
puts("YES");
puts("");
return ;
}
flag=true;
dfs(item1,-,item1);
if(flag)
{
puts("YES");
printf("%d\n",item1);
return ;
}
flag=true;
dfs(item2,-,item2);
if(flag)
{
puts("YES");
printf("%d\n",item2);
return ;
}
puts("NO");
return ;
}
D. Timofey and rectangles
题目大意:给你n个矩形,且矩形的边长为奇数,任意两个矩形都不相交,最多相邻,现在让你给这些矩形上色,
一种4种颜色,相邻的矩形颜色不能相等,问你有没有这样的方案,如果有则输出。
思路:赤裸裸的脑洞题,专门碾压我这种低智商的,这题最关键的是矩形的边长是奇数,虽然我知道,但是
我还是不会写QAQ。
首先,四个矩形不可能两两互相相邻,所以结论一定是YES
然后,我们考虑矩形的左下角的顶点,如果 x 和 y 的值都为奇数,因为边长是奇数,所以这个矩形不可能和
另一个左下角坐标都为奇数的矩形相邻。所以我们给这类矩形染色 1 。
其他三种同理。
#include<bits/stdc++.h>
using namespace std;
const int N=*1e5+;
int n,vis[N],m=1e9;
int main()
{
cin>>n;
for(int i=;i<=n;i++)
{
int x1,y1,x2,y2;
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
if((x1+m)% && (y1+m)%) vis[i]=;
else if((x1+m)%) vis[i]=;
else if((y1+m)%) vis[i]=;
else vis[i]=;
}
cout<<"YES"<<endl;
for(int i=;i<=n;i++) printf("%d\n",vis[i]);
return ;
}
Codeforces Round #395 (Div. 2)的更多相关文章
- Codeforces Round #395 (Div. 2)(A.思维,B,水)
A. Taymyr is calling you time limit per test:1 second memory limit per test:256 megabytes input:stan ...
- Codeforces Round #395 (Div. 2) D. Timofey and rectangles
地址:http://codeforces.com/contest/764/problem/D 题目: D. Timofey and rectangles time limit per test 2 s ...
- Codeforces Round #395 (Div. 2) C. Timofey and a tree
地址:http://codeforces.com/contest/764/problem/C 题目: C. Timofey and a tree time limit per test 2 secon ...
- Codeforces Round #395 (Div. 2)B. Timofey and cubes
地址:http://codeforces.com/contest/764/problem/B 题目: B. Timofey and cubes time limit per test 1 second ...
- Codeforces Round #395 (Div. 1)
比赛链接:http://codeforces.com/contest/763 A题: #include <iostream> #include <cstdio> #includ ...
- Codeforces Round #395 (Div. 2)(未完)
2.2.2017 9:35~11:35 A - Taymyr is calling you 直接模拟 #include <iostream> #include <cstdio> ...
- 【分类讨论】Codeforces Round #395 (Div. 2) D. Timofey and rectangles
D题: 题目思路:给你n个不想交的矩形并别边长为奇数(很有用)问你可以可以只用四种颜色给n个矩形染色使得相接触的 矩形的颜色不相同,我们首先考虑可不可能,我们分析下最多有几个矩形互相接触,两个时可以都 ...
- 【树形DP】Codeforces Round #395 (Div. 2) C. Timofey and a tree
标题写的树形DP是瞎扯的. 先把1看作根. 预处理出f[i]表示以i为根的子树是什么颜色,如果是杂色的话,就是0. 然后从根节点开始转移,转移到某个子节点时,如果其子节点都是纯色,并且它上面的那一坨结 ...
- Codeforces Round #395 (Div. 2) C
题意 : 给出一颗树 每个点都有一个颜色 选一个点作为根节点 使它的子树各自纯色 我想到了缩点后check直径 当<=3的时候可能有解 12必定有解 3的时候需要check直径中点的组成点里是否 ...
随机推荐
- 序列化时提示There was an error reflecting type 'System.Collections.Generic.List`1
序列化xml文件到List中,非win10下出现了这个错误,但是在win10下正常.经过仔细的研究,发现是序列化工具类不能使用Static.去掉Static即可.
- js设置div透明度
原生js设置透明度 为了兼容IE与其他浏览器对透明度的设置,我们需要对以上两种样式分别进行设置: 复制代码代码如下: var alpha = 30; //透明度值变量 var oDiv = docum ...
- 错误RSA host key for [ip address] has changed and you have requested strict checking.
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ WARNING: REMOTE HOST IDENTIFICATION HAS ...
- postman变量的使用和设置
之前只是使用postman做接口管理——将各个项目使用到的接口分类管理起来,用的时候手动改参数调用.这次项目连着跑三个接口,需要用到前一个接口的参数,还来回切平台,真的很麻烦,所以就搜了一下有什么便利 ...
- Python中的部分特殊属性
__name__ is the class name; 返回类名 __module__ is the module name in which the class was defined; 定 ...
- nvm安装与使用
1.nvm是什么 nvm全名node.js version management,顾名思义是一个nodejs的版本管理工具.通过它可以安装和切换不同版本的nodejs.下面列出下载.安装及使用方法. ...
- Nginx软件优化【转】
转自 Nginx软件优化 - 惨绿少年 - 博客园 Nginx软件优化 - 惨绿少年 - 博客园 https://www.cnblogs.com/clsn/p/8484559.html 1.1 Ngi ...
- 异步编程之使用yield from
异步编程之使用yield from yield from 是 Python3.3 后新加的语言结构.yield from的主要功能是打开双向通道,把最外层的调用方法与最内层的子生成器连接起来.这两者就 ...
- mysql系列十、mysql索引结构的实现B+树/B-树原理
一.MySQL索引原理 1.索引背景 生活中随处可见索引的例子,如火车站的车次表.图书的目录等.它们的原理都是一样的,通过不断的缩小想要获得数据的范围来筛选出最终想要的结果,同时把随机的事件变成顺序的 ...
- 深入解析内存原理:SRAM的基本原理
1. SRAM芯片的引脚定义早期的SRAM 芯片采用了20 线双列直插(DIP:Dual Inline Package)封装技术,它们之所以具有这么多的针脚,是因为它们必须:• 每个地址信号都需要一根 ...