Codeforces Round #544 (Div. 3) D F1 F2
题目链接:D. Zero Quantity Maximization
#include <bits/stdc++.h>
using namespace std;
#define maxn 200005
#define LL long long
#define pii pair<LL,LL>
map<pair<LL,LL>,LL>mp,mpp;
LL a[maxn],b[maxn];
LL gcd(LL a,LL b){
return b?gcd(b,a%b):a;
}
int main(){
LL n;
scanf("%lld",&n);
;j<n;j++){
scanf("%lld",&a[j]);
}
;k<n;k++){
scanf("%lld",&b[k]);
}
LL mx = ,ans = ;
;j<n;j++){
LL z = gcd(abs(a[j]),abs(b[j]));
){
a[j] = -a[j];
b[j] = -b[j];
}
){
) ans++;
continue;
}
){
mp[make_pair(1LL*,1LL*)]++;
mx = max(mx, mp[make_pair(1LL*,1LL*)]);
continue;
}
mp[make_pair(a[j]/z,b[j]/z)]++;
mx = max(mx, mp[make_pair(a[j]/z,b[j]/z)]);
}
printf("%lld\n",mx+ans);
}
F1: Spanning Tree with Maximum Degree
判断一下 bfs 就ok
#include<bits/stdc++.h>
using namespace std;
#define maxn 200005
#define LL long long
vector<int>q[maxn];
int fa[maxn];
bool flag[maxn];
void bfs(int u){
queue<int>Q;
Q.push(u);
while(!Q.empty()){
u = Q.front();
Q.pop();
;j<q[u].size();j++){
int v = q[u][j];
if(!flag[v]){
flag[v] = ;
Q.push(v);
printf("%d %d\n",u,v);
}
}
}
}
int main(){
memset(fa,,sizeof(fa));
memset(flag,,sizeof(flag));
,;
scanf("%d%d",&n,&m);
;j<m;j++){
int u,v;
scanf("%d%d",&u,&v);
q[u].push_back(v);
q[v].push_back(u);
fa[u]++;
fa[v]++;
if(mx<fa[u]){
mx = fa[u];
in = u;
}
if(mx<fa[v]){
mx = fa[v];
in = v;
}
}
// cout<<in<<endl;
flag[;
bfs(in);
}
F2 :F2. Spanning Tree with One Fixed Degree
先判断 节点的度够不够 不够直接 输出 NO
dfs 判断1有多少个连通块 如果连通块数量 大于d 直接输出NO
最后 添加 在 1 节点添加 d-连通块个数个 点 bfs
#include <bits/stdc++.h>
using namespace std;
#define maxn 200005
#define LL long long
#define pii pair<int,int>
vector<int>q[maxn],z;
vector<pii>lis;
bool fa[maxn];
int n,m,d;
void dfs(int u){
;j<q[u].size();j++){
int v = q[u][j];
if(!fa[v]){
fa[v] = ;
dfs(v);
}
}
}
bool bfs(int u){
queue<int>Q;
;
Q.push(u);
while(!Q.empty()){
u = Q.front();
Q.pop();
;j<q[u].size();j++){
int v = q[u][j];
if(!fa[v]){
fa[v] = ,sum++;
Q.push(v);
//cout<<u<<" "<<v<<endl;
lis.push_back(make_pair(u,v));
){
d--;
) break;
}
}
}
}
//cout<<sum<<" "<<n-1<<endl;
)) ;
;
}
int main(){
scanf("%d%d%d",&n,&m,&d);
memset(fa,,sizeof(fa));
;
;j<m;j++){
int u,v;
scanf("%d%d",&u,&v);
q[u].push_back(v);
q[v].push_back(u);
||v==) sum++;
}
if(sum<d){
printf("NO\n");
;
}
fa[]=;
set<int>se;
;j<q[].size();j++){
][j];
if(!fa[v]){
fa[v]=;
se.insert(v);
dfs(v);
}
}
//cout<<se.size()<<endl;
if(se.size()>d){
printf("NO\n");
;
}
//cout<<*se.begin()<<endl;
;j<q[].size()&&se.size()<d;j++){
se.insert(q[][j]);
}
q[].clear();
for(auto &i:se){
//cout<<i<<endl;
q[].push_back((int)i);
}
memset(fa,,sizeof(fa));
fa[] = ;
bfs();
printf("YES\n");
;j<lis.size();j++){
pii pa = lis[j];
printf("%d %d\n",pa.first,pa.second);
}
}
Codeforces Round #544 (Div. 3) D F1 F2的更多相关文章
- Codeforces Round #544 (Div. 3) 题解
Codeforces Round #544 (Div. 3) D. Zero Quantity Maximization 题目链接:https://codeforces.com/contest/113 ...
- CodeForces Round #544 Div.3
A. Middle of the Contest 代码: #include <bits/stdc++.h> using namespace std; int h1, m1, h2, m2; ...
- Codeforces Round #544 (Div. 3)解题报告
A.Middle of the Contest 考虑把输入的时间单位化成分钟,相加除以2就好了 #include<bits/stdc++.h> using namespace std; # ...
- Codeforces Round #544 (Div. 3) (补)
D:没有注意到a==0&&b==0的情况,把自己卡崩了.对于数学公式推导一定要注意关于0的特殊情况,不可以少 #include <iostream> #include &l ...
- Codeforces Round #544 (Div. 3) dp + 双指针
https://codeforces.com/contest/1133/problem/E 题意 给你n个数(n<=5000),你需要对其挑选并进行分组,总组数不能超过k(k<=5000) ...
- Codeforces Round #544 (Div. 3) D. Zero Quantity Maximization
链接:https://codeforces.com/contest/1133/problem/D 题意: 给两个数组a,b. 同时ci = ai * d + bi. 找到一个d使c数组中的0最多. 求 ...
- Codeforces Round #544 (Div. 3) C. Balanced Team
链接:https://codeforces.com/contest/1133/problem/C 题意: 给n个数, 在这n个数中选最多n个数,来组成一个队伍. 保证这n个数的最大最小差值不大于5. ...
- Codeforces Round #544 (Div. 3) B.Preparation for International Women's Day
链接:https://codeforces.com/contest/1133/problem/B 题意: 给n个数,和一个k,在n个数中选几对数,保证没对数相加可以整除k. 求最大能选几个数. 思路: ...
- Codeforces Round #544 (Div. 3) A.Middle of the Contest
链接:https://codeforces.com/contest/1133/problem/A 题意: 给两个时间点,求中间时间点. 思路: 数学 代码: #include <bits/std ...
随机推荐
- Java web的一些面试题
1.Tomcat 的优化经验 答:去掉对 web.xml 的监视,把 jsp 提前编辑成 Servlet. 有富余物理内存的情况,加大 tomcat 使用的 jvm 的内存 2.HTTP 请求的 GE ...
- arcgis api 3.x for js 入门开发系列十五台风轨迹
前言 关于本篇功能实现用到的 api 涉及类看不懂的,请参照 esri 官网的 arcgis api 3.x for js:esri 官网 api,里面详细的介绍 arcgis api 3.x 各个类 ...
- Android应用跳转到微信和支付宝扫一扫
新版的微信已经把微信功能的schema都禁掉了,意味着我们无法打开微信的扫一扫等功能,目前正常的只能先进入微信(我测试的时候是微信版本7.0.3)已经是很新的版本了 具体调起微信扫一扫代码如下,测试后 ...
- vmware 6 虚拟化 全系列 序列号
vmware 6 虚拟化 全系列 序列号 vSphere 6 Hypervisor HY0XH-D508H-081U8-JA2GH-CCUM2 4C4WK-8KH8L-H85J0-UHCNK-8C ...
- codeforces div2 220 解题
这套题我只写了a, b, c.. 对不起,是我太菜了. A:思路:就是直接简化为一个矩阵按照特定的步骤从一个顶角走到与之对应的对角线上的顶角.如图所示. 解释一下特定的步骤,就像马走日,象走田一样. ...
- [原创]Java应用性能远程监控系统(C/S架构)
Java应用性能远程监控系统(使用C/S架构) 适用于监控所有Java应用,具有堆内存监控.方法区监控.GC监控.类加载监控.类编译监控与线程监控,提供堆快照下载,线程快照下载.体验网址:http:/ ...
- nextInt()和nextLine()一起使用时的注意点
问题原因:nextLine()会把nextInt(),next(),nextDouble(),nextFloat()的结束换行符作为字符串读入,进而不需要从键盘输入字符串nextLine便已经转向了下 ...
- 升级:DNAtools for Excel工具箱,2.x英文版- VBA代码破解工具
原始出处:www.cnblogs.com/Charltsing/p/DnaTools.html QQ:564955427 DNA工具箱全部功能一览: 单元格焦点指示(支持Excel 2007~2 ...
- 美化ubuntu18.04,并安装搜狗输入法
目录 美化Ubuntu 下载主题和图标文件 下载GNOME3 美化过程 安装输入法 下载并安装搜狗输入法 安装fcitx框架 安装过程 美化Ubuntu 下载主题和图标文件 下载地址:https:// ...
- laravel 定义翻译字符串
https://learnku.com/docs/laravel/5.6/localization/1376 // 全景链接$data['share_phone'] = trans('web.host ...