题目链接: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的更多相关文章

  1. Codeforces Round #544 (Div. 3) 题解

    Codeforces Round #544 (Div. 3) D. Zero Quantity Maximization 题目链接:https://codeforces.com/contest/113 ...

  2. CodeForces Round #544 Div.3

    A. Middle of the Contest 代码: #include <bits/stdc++.h> using namespace std; int h1, m1, h2, m2; ...

  3. Codeforces Round #544 (Div. 3)解题报告

    A.Middle of the Contest 考虑把输入的时间单位化成分钟,相加除以2就好了 #include<bits/stdc++.h> using namespace std; # ...

  4. Codeforces Round #544 (Div. 3) (补)

    D:没有注意到a==0&&b==0的情况,把自己卡崩了.对于数学公式推导一定要注意关于0的特殊情况,不可以少 #include <iostream> #include &l ...

  5. Codeforces Round #544 (Div. 3) dp + 双指针

    https://codeforces.com/contest/1133/problem/E 题意 给你n个数(n<=5000),你需要对其挑选并进行分组,总组数不能超过k(k<=5000) ...

  6. 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最多. 求 ...

  7. Codeforces Round #544 (Div. 3) C. Balanced Team

    链接:https://codeforces.com/contest/1133/problem/C 题意: 给n个数, 在这n个数中选最多n个数,来组成一个队伍. 保证这n个数的最大最小差值不大于5. ...

  8. Codeforces Round #544 (Div. 3) B.Preparation for International Women's Day

    链接:https://codeforces.com/contest/1133/problem/B 题意: 给n个数,和一个k,在n个数中选几对数,保证没对数相加可以整除k. 求最大能选几个数. 思路: ...

  9. Codeforces Round #544 (Div. 3) A.Middle of the Contest

    链接:https://codeforces.com/contest/1133/problem/A 题意: 给两个时间点,求中间时间点. 思路: 数学 代码: #include <bits/std ...

随机推荐

  1. 如何在Linux服务器和windows系统之间上传与下载文件

    Do not let dream just be your dream. 背景:Linux服务器文件上传下载. XShell+Xftp安装包(解压即用)百度网盘链接:https://pan.baidu ...

  2. java的设计模式 - 单例模式

    java 面试中单例模式基本都是必考的,都有最推荐的方式,也不知道问来干嘛.下面记录一下 饿汉式(也不知道为何叫这个名字) public class Singleton { private stati ...

  3. js调用百度地图接口绘制任意多边形并获取每个点的经纬度等

    来自:https://blog.csdn.net/u013239236/article/details/52213977 侵删 <!DOCTYPE html> <html> & ...

  4. rocketmq广播消息

    发布与模式实现.广播就是向一个主题的所有订阅者发送同一条消息. 在发送消息的时候和普通的消息并与不同之处,只是在消费端做一些配置即可. Consumer消息消费 public class Broadc ...

  5. 太嚣张了!他竟用Python绕过了“验证码”

    在web页面中,经常会遇到验证码,这对于我这么一个热爱web自动化测试人员,就变成了一件头疼的事.于是千方百计找各种资源得到破解简单的验证码方法. 识别验证码 大致分如下几个步骤: 1.获取验证码图片 ...

  6. Spark 基本函数学习笔记一

      Spark 基本函数学习笔记一¶ spark的函数主要分两类,Transformations和Actions. Transformations为一些数据转换类函数,actions为一些行动类函数: ...

  7. SQL Server中将多行数据拼接为一行数据(一个字符串)

    表A中id与表B中aid为一对多的关系 例如: 表A: id name a1 tom a2 lily a3 lucy 表B: id aid value b1 a1 B1 b2 a1 B2 b3 a2 ...

  8. LeetCode算法题-Reach a Number(Java实现)

    这是悦乐书的第310次更新,第331篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第179题(顺位题号是754).你站在无限数字线的0号位置.在目的地有个target.在 ...

  9. 51Nod 1004 n^n的末位数字

    思路:首先将0~9的平方的尾数放在一个数组a里面,方便后面直接调用,因为不论多大的数做什么运算,得到的结果的最后一位数只和运算前所有数的最后一位数有关系.新建变量d,z一个是底数,一个是幂次.循环判断 ...

  10. C/C++中容器vector用法

    C++中数组非常坑,有没有相似Python中list的数据类型呢?相似的就是vector!vector 是同一种类型的对象的集合,每一个对象都有一个对应的整数索引值. 和 string 对象一样.标准 ...