Codeforces Round #411 (Div. 2) 【ABCDE】
A. Fake NP
题意:给你l,r,让你输出[l,r]里面除1以外的,出现因子数量最多的那个数。
题解:如果l==r输出l,否则都输出2
#include<bits/stdc++.h>
using namespace std;
int main(){
int l,r;
cin>>l>>r;
if(r-l==0){
cout<<l<<endl;
return 0;
}
int ans = 0;
int num = 0;
for(int i=2;i<=10000;i++){
if(r/i-(l-1)/i>num)
num = r/i-(l-1)/i,ans = i;
}
cout<<ans<<endl;
}
B. 3-palindrome
题意:给你n,你需要构造一个长度为n的,不存在长度为3的回文串的串。
题解:aabbaabbaabbaabb这样一直构造下去就好了。
#include<bits/stdc++.h>
using namespace std;
int main(){
int n;
cin>>n;
for(int i=0;i<n;i++){
if(i%4==0)cout<<"a";
else if(i%4==1)cout<<"a";
else if(i%4==2)cout<<"b";
else if(i%4==3)cout<<"b";
}
cout<<endl;
}
C. Find Amir
题意:从i到j的代价是(i+j)%(n+1),问你经过所有点的最小代价是多少
题解:显然就是(n-1)/2
#include<bits/stdc++.h>
using namespace std;
int main(){
long long ans = 0;
long long n;
cin>>n;
if(n==1){
cout<<"0"<<endl;
return 0;
}
ans = (n/2-1);
if(n%2==1)ans++;
cout<<ans<<endl;
}
D. Minimum number of steps
题意:你的每一次操作,会使得一个ab变成bba,问你最多进行多少次操作
题解:显然最后的答案会变成bbbbbbbaaaaaaa,那么我们倒着看,每次遇到一个b,就会使得b的数量加一,遇到一个a,就会花费当前b的数量,移动到最后,并且使得b的数量翻倍。
#include<bits/stdc++.h>
using namespace std;
const long long mod = 1e9+7;
long long ans = 0;
string s;
int main(){
cin>>s;
reverse(s.begin(),s.end());
long long B = 0;
long long A = 0;
for(int i=0;i<s.size();i++){
if(s[i]=='a'){
ans = (ans + B)%mod;
B = B * 2LL % mod;
}else{
B = (B + 1)% mod;
}
}
cout<<ans<<endl;
}
E. Ice cream coloring
题意:给你一棵树,然后树上的每个点有一堆颜色,保证每个颜色都会组成一个联通块。现在让你输出一个方案,使得出现在同一个点的颜色都各不相同。
题解:如果不给你一棵树这个条件,那么这就是一个np问题。但是他给了,说明这就是个xjb贪心的问题……
首先最大的颜色数量,就是点的最大颜色数量。然后我们贪心的去涂颜色就好了。
但是有个数据:
3 2
1 1
1 2
2 1 2
1 3
2 3
所以我们得按照一定的顺序去涂颜色就行。
(好像这棵树的条件还是没用上。。。
#include<bits/stdc++.h>
using namespace std;
const int maxn = 3e5+7;
int n,m;
vector<int>E[maxn],G[maxn],H[maxn];
int vis[maxn];
int ans[maxn];
map<int,int>H2[maxn];
queue<int>Q;
int tot;
void solve(int i){
for(int j=0;j<E[i].size();j++){
int v = E[i][j];
if(ans[v]!=0)continue;
while(H2[i][tot]==1)tot++;
ans[v]=tot;
H2[i][tot]=1;
for(int k=0;k<H[v].size();k++){
if(H2[H[v][k]][tot]==0){
Q.push(H[v][k]);
}
H2[H[v][k]][tot]=1;
}
}
vis[i]=1;
}
int main(){
scanf("%d%d",&n,&m);
int Ans = 0;
for(int i=1;i<=n;i++){
int p;
scanf("%d",&p);
for(int j=0;j<p;j++){
int x;
scanf("%d",&x);
E[i].push_back(x);
H[x].push_back(i);
}
}
for(int i=1;i<n;i++){
int x,y;
scanf("%d%d",&x,&y);
G[x].push_back(y);
G[y].push_back(x);
}
for(int i=1;i<=n;i++){
tot = 1;
if(vis[i])continue;
solve(i);
while(!Q.empty()){
int now = Q.front();
tot = 1;
Q.pop();
if(vis[now])continue;
solve(now);
}
}
for(int i=1;i<=m;i++)
if(ans[i]==0)
ans[i]=1;
for(int i=1;i<=m;i++)
Ans=max(Ans,ans[i]);
cout<<Ans<<endl;
for(int i=1;i<=m;i++)
cout<<ans[i]<<" ";
cout<<endl;
}
Codeforces Round #411 (Div. 2) 【ABCDE】的更多相关文章
- Codeforces Round #677 (Div. 3)【ABCDE】
比赛链接:https://codeforces.com/contest/1433 A. Boring Apartments 题解 模拟即可. 代码 #include <bits/stdc++.h ...
- Codeforces Round #382 Div. 2【数论】
C. Tennis Championship(递推,斐波那契) 题意:n个人比赛,淘汰制,要求进行比赛双方的胜场数之差小于等于1.问冠军最多能打多少场比赛.题解:因为n太大,感觉是个构造.写写小数据, ...
- Codeforces Round #684 (Div. 2)【ABC1C2】
比赛链接:https://codeforces.com/contest/1440 A. Buy the String 题解 枚举字符串中 \(0\) 或 \(1\) 的个数即可. 代码 #includ ...
- Codeforces Round #682 (Div. 2)【ABCD】
比赛链接:https://codeforces.com/contest/1438 A. Specific Tastes of Andre 题意 构造一个任意连续子数组元素之和为子数组长度倍数的数组. ...
- Codeforces Round #678 (Div. 2)【ABCD】
比赛链接:https://codeforces.com/contest/1436 A. Reorder 题解 模拟一下这个二重循环发现每个位置数最终都只加了一次. 代码 #include <bi ...
- Codeforces Round #676 (Div. 2)【ABCD】
比赛链接:https://codeforces.com/contest/1421 A. XORwice 题意 给出两个正整数 \(a.b\),计算 \((a \oplus x) + (b \oplus ...
- Codeforces Round #675 (Div. 2)【ABCD】
比赛链接:https://codeforces.com/contest/1422 A. Fence 题意 给出三条边 $a,b,c$,构造第四条边使得四者可以围成一个四边形. 题解 $d = max( ...
- Codeforces Round #668 (Div. 2)【ABCD】
比赛链接:https://codeforces.com/contest/1405 A. Permutation Forgery 题意 给出一个大小为 $n$ 的排列 $p$,定义 \begin{equ ...
- Codeforces Round #658 (Div. 2)【ABC2】
做完前四题还有一个半小时... 比赛链接:https://codeforces.com/contest/1382 A. Common Subsequence 题意 给出两个数组,找出二者最短的公共子序 ...
随机推荐
- Oracle12c 性能优化攻略:攻略1-1:创建具有最优性能的数据库
一:章节前言 本章着眼于影响表中数据存储性能的数据库特性. 表的性能部分取决于在创建之前所应用的数据库特性.例如:在最初创建数据库时采用的物理存储特性以及相关的表空间都会在后来影响表的性能.类似地,表 ...
- C++ code:More Loop Designs
1 逻辑判断 对于逻辑判断问题,一般都要考虑全部的可能性,然后从这些可能性中按条件逐一排查,直到最后获得某个结论. [百钱买百鸡问题] 问题描述: 雄鸡(cock)7元一只,母鸡(hen)5元一只, ...
- python 全栈开发,Day9(函数的初始,返回值,传参,三元运算)
一.函数的初始 比如python没有len()方法,如何求字符串的长度使用for循环 s = 'fdshfeigjoglfkldsja' count = 0 for i in s: count += ...
- Ext.js中自己扩展的EasyGrid
这里只写了一些核心的代码,具体如下: Ext.ux.EasyGrid = Ext.extend(Ext.grid.GridPanel, { initComponent: function () { t ...
- JQuery动画详解(四)
一:基本动画show()显示隐藏的匹配元素.这个就是 'show( speed, [callback] )' 无动画的版本.如果选择的元素是可见的,这个方法将不会改变任何东西.无论这个元素是通过hid ...
- 深度优先搜索(DFS)和广度优先搜索(BFS)
深度优先搜索(DFS) 广度优先搜索(BFS) 1.介绍 广度优先搜索(BFS)是图的另一种遍历方式,与DFS相对,是以广度优先进行搜索.简言之就是先访问图的顶点,然后广度优先访问其邻接点,然后再依次 ...
- SpringMVC异常处理器
本节内容: 异常处理思路 自定义异常类 自定义异常处理器 异常处理器配置 错误页面 异常测试 springmvc在处理请求过程中出现异常信息交由异常处理器进行处理,自定义异常处理器可以实现一个系统的异 ...
- webpack 使用环境变量
要在开发和生产构建之间,消除 webpack.config.js 的差异.你可能需要环境变量. 可以使用 Node.js 模块的标准方式:在运行 webpack 时设置环境变量,并且使用 Node.j ...
- bzoj2654
题解: 老早看的并没有写 wqs二分的原理和这个凸函数的性质已经证明过了 写的时候 主要的问题在于每次的答案是一个范围 什么意思呢 其实比较简单的做法是 优先取白边,优先取黑边做两次 然后看一下要求的 ...
- zjoi 网络
题解: 很显然会发现对于每种颜色分开处理这是一颗树 然后就是裸的lct 有个坑就是判断操作1 可能颜色改成跟原先一样的 代码: #include <bits/stdc++.h> using ...