-------------------昨天打的重现赛,感觉是我打的发挥的最好的一场比赛了,六题都一次AC。那么就来总结一下吧

题目链接:http://codeforces.com/contest/1133

A .Middle of the Contest

sol:简单模拟,注意一下跨天的情况就好了。

  • 模拟

    #include "bits/stdc++.h"
    using namespace std;
    int main() {
    int h1, m1, h2, m2, k;
    scanf("%d:%d%d:%d", &h1, &m1, &h2, &m2);
    // 把第二个时间加24小时,就能保证第二个时间比第一个时间大
    k = (m2 - m1 + (h2 + - h1) * ) % ( * ) >> ;
    m1 += k;
    h1 = (h1 + m1 / ) % ;
    m1 %= ;
    printf("%02d:%02d", h1, m1);
    return ;
    }

B .Preparation for International Women's Day

sol:如果(a + b) % k == 0,那么(a % k) + (b % k) == 0 || (a % k) + (b % k) == k。注意等于0的情况不要忽略掉。遍历一遍,对于第d[i],查看是否在前面出现过还未配对的余数和d[i]余数相加等于0或k的情况。

  • 同余

    #include "bits/stdc++.h"
    using namespace std;
    const int MAXN = ;
    int n, k, v, ans;
    int cnt[MAXN];
    int main() {
    scanf("%d%d", &n, &k);
    for (int i = ; i <= n; i++) {
    scanf("%d", &v);
    v %= k;
    if (cnt[(k - v) % k]) {
    ans += ;
    cnt[(k - v) % k]--;
    } else {
    cnt[v]++;
    }
    }
    printf("%d\n", ans);
    return ;
    }

C .Balanced Team

sol:尺取法,先排序,定义l = r = 1。然后让l和r一起往右移。

  • 尺取法

    #include "bits/stdc++.h"
    using namespace std;
    const int MAXN = 2e5 + ;
    int arr[MAXN], n, ans;
    int main() {
    scanf("%d", &n);
    for (int i = ; i <= n; i++) {
    scanf("%d", &arr[i]);
    }
    sort(arr + , arr + + n);
    int l = , r = ;
    while (r <= n) {
    while (arr[r] - arr[l] > ) l++;
    ans = max(ans, r - l + );
    r++;
    }
    printf("%d\n", ans);
    return ;
    }

D .Zero Quantity Maximization

sol:首先换个姿势看这个问题,c[i] = d * a[i] + b[i],求c数组0最多有几个,那么我让题目变成c[i] = a[i]和b[i]的比。求相同比最多的次数。用map计数就行了。但是这个比不能用double来计,会产生精度丢失。所以我是用pair来计比的。还有就要说说这题的样例了,a[i] == 0这种属于特殊数据怎么能放到样例里呢,虽然我一开始也没考虑到。注意约分的时候a[i]为0的情况;

  • 这题考细心

    #include "bits/stdc++.h"
    using namespace std;
    typedef pair<int, int> PII;
    const int MAXN = 2e5 + ;
    map<PII, int> mp;
    int a[MAXN], b[MAXN];
    int ans, n, k, g;
    int main() {
    scanf("%d", &n);
    for (int i = ; i <= n; i++)
    scanf("%d", &a[i]);
    for (int i = ; i <= n; i++)
    scanf("%d", &b[i]);
    for (int i = ; i <= n; i++) {
    if (a[i] == ) {
    k += (b[i] == );
    continue;
    }
    g = __gcd(a[i], b[i]);
    a[i] /= g, b[i] /= g;
    mp[{a[i], b[i]}]++;
    ans = max(ans, mp[{a[i], b[i]}]);
    }
    printf("%d\n", ans + k);
    return ;
    }

E .K Balanced Teams

sol:动态规划,先sort一下。dp[i][j]表示从第i个队员到最后一个队员组成j个队伍最多的人数。

ps:除了动态规划的部分,其他的和C题都一样。不过数据范围比较小,尺取法不是关键考点。用暴力也能过。

  • 动态规划

    #include "bits/stdc++.h"
    using namespace std;
    const int MAXN = ;
    int arr[MAXN];
    int dp[MAXN][MAXN];
    int ans;
    int main() {
    int n, m;
    scanf("%d%d", &n, &m);
    for (int i = ; i <= n; i++)
    scanf("%d", &arr[i]);
    sort(arr + , arr + + n);
    for (int i = n; i >= ; i--) {
    int k = i;
    while (k <= n && arr[k] - arr[i] <= ) k++;
    for (int j = ; j <= m; j++) {
    dp[i][j] = max(dp[i + ][j], k - i + dp[k][j - ]);
    ans = max(ans, dp[i][j]);
    }
    }
    printf("%d\n", ans);
    return ;
    }

F1 .Spanning Tree with Maximum Degree

sol:找到度数最大的节点,以度数最大的节点为起点bfs遍历全图

  • 图算法

    #include "bits/stdc++.h"
    using namespace std;
    const int MAXN = 2e5 + ;
    vector<int> edge[MAXN];
    int maxdg, pos;
    bool use[MAXN];
    void bfs(int pos) {
    queue<int> que;
    que.push(pos);
    use[pos] = true;
    while (!que.empty()) {
    pos = que.front();
    que.pop();
    for (int i = ; i < edge[pos].size(); i++) {
    if (!use[edge[pos][i]]) {
    printf("%d %d\n", pos, edge[pos][i]);
    que.push(edge[pos][i]);
    use[edge[pos][i]] = true;
    }
    }
    }
    }
    int main() {
    int n, m, u, v;
    scanf("%d%d", &n, &m);
    for (int i = ; i <= m; i++) {
    scanf("%d%d", &u, &v);
    edge[u].push_back(v);
    edge[v].push_back(u);
    if (edge[u].size() > maxdg) {
    maxdg = edge[u].size();
    pos = u;
    }
    if (edge[v].size() > maxdg) {
    maxdg = edge[v].size();
    pos = v;
    }
    }
    bfs(pos);
    return ;
    }

CF-544:部分题目总结的更多相关文章

  1. CF 题目选做

    写省选的题目对noip没什么大用 关键是 细节题或者是思考题比较重要 练思维自然是CF比较好了 把我见到的比较好的CF题放上来刷一刷. LINK:Complete the projects 就是说一个 ...

  2. CF 219D 树形DP

    CF 219D [题目链接]CF 219D [题目类型]树形DP &题意: 给一个n节点的有向无环图,要找一个这样的点:该点到其它n-1要逆转的道路最少,(边<u,v>,如果v要到 ...

  3. 跟着xiaoxin巨巨做cf

    cf 385 C. Bear and Prime Numbers 题目大意:有一个数列{xi},每次给出一个询问[l, r],即问 S(l ,r)是l和r之间的素数,f(p)表示数列{xi}中整除p的 ...

  4. Codeforces Round #379 (Div. 2) 解题报告

    题目地址 本次CF是在今天早上深夜进行,上午有课就没有直接参加.今天早上上课坐到后排参加了virtual participation.这次CF前面的题目都非常的水,不到10分钟就轻松过了前两题,比较郁 ...

  5. Miaomiao's Geometry

    HDU 4932  Bestcoder Problem Description There are N point on X-axis . Miaomiao would like to cover t ...

  6. Codeforces Round #221 (Div. 2) C. Divisible by Seven(构造 大数除法 )

    上几次的一道cf题. 题目:http://codeforces.com/contest/376/problem/C 性质: (4)a与b的和除以c的余数(a.b两数除以c在没有余数的情况下除外),等于 ...

  7. 【小TIP】记录各种错误【更新中】

    最好程序一遍通过,为了提高代码能力,这里将用TIP的形式记录来犯过的错误.不断更新中. *已经转移到闪存.. [150214]WA:检查是否数组开小了. [150212]WA:如果程序中有乘号,需要留 ...

  8. Codeforces Round #242 (Div. 2) &lt;A-D&gt;

    CF424 A. Squats 题目意思: 有n(n为偶数)个x和X,求最少的变换次数,使得X的个数为n/2,输出变换后的序列. 解题思路: 统计X的个数ans,和n/2比較,少了的话,须要把n/2- ...

  9. [CF1107E]Vasya and Binary String【区间DP】

    题目描述 Vasya has a string s of length n consisting only of digits 0 and 1. Also he has an array a of l ...

  10. CF1131F Asya And Kittens(Kruskal重构树,启发式合并)

    这题难度1700,我感觉又小了…… 这题虽然没几个人是用kruskal重构树的思想做的,但是我是,所以我就放了个kruskal重构树的标签. 题目链接:CF原网 题目大意:有一个长为 $n$ 的排列, ...

随机推荐

  1. python刷LeetCode:5. 最长回文子串

    难度等级:中等 题目描述: 给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为 1000. 示例 1: 输入: "babad"输出: "bab& ...

  2. pycharm2018专业版

    https://blog.csdn.net/moshanghuali/article/details/94396935 1 下载Pycharm专业版2018.3.1许多人直接在官网直接下载,默认的都是 ...

  3. 开始新建AEM站点-周末教程

    Getting Started Developing AEM Sites - WKND Tutorial 开始新建AEM站点-周末教程 The goal for this multi-part tut ...

  4. 38. docker cloud 简介及 关联 git hub

    1.概念 提供 容器的管理, 编排, 部署 的托管服务 2.功能 image 管理 创建 stack 创建服务 service 添加 节点 作为 docker host 自动关联云服务商 AWS  A ...

  5. spring中的Filter使用

    https://blog.csdn.net/bibiwannbe/article/details/81302920

  6. block内存篇

    本文目的:对Block内存问题更加了解 概念理解:一种数据类型或比较特殊的对象,相当于一个指向函数的指针,该指针指向一段封装代码,调用block块代码好比调用该指针指向的函数代码 block分类: N ...

  7. protobuf编译工具使用

    1.下载,配置环境变量 下载地址:https://github.com/google/protobuf/releases,选择protoc-xxx-win64.zip下载 把.exe文件的位置加入到P ...

  8. 使用PHANTOMJS对网页截屏

    PhantomJS 是一个基于 WebKit 的服务器端 JavaScript API.它全面支持web而不需浏览器支持,其快速,原生支持各种Web标准: DOM 处理, CSS 选择器, JSON, ...

  9. Python 学习笔记:根据输入年月区间,返回期间所有的月份

    目的: 给定一个年月区间,比如:2019.01 至 2019.05,要求返回一个包含期间所有的月份的列表,比如:['2019.01', '2019.02', '2019.03', '2019.04', ...

  10. 添加并启动MySQL服务

    1. 右键开始菜单,选择 2. 进入到MySQL安装目录下的bin目录,输入命令: mysqld.exe -install 3.启动mysql服务,输入命令: net start mysql