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

A .Serval and Bus

pro:给出n种公交车的首班车时间和两班车之间的时间间隔,找t时间以后的第一辆车是第几种车

sol:对于每种车,找到t时间以后的第一班车的时间,计算这个时间和t的差距,然后找离t最近的

  • 暴力

    #include "bits/stdc++.h"
    using namespace std;
    const int MAXN = ;
    const int INF = 0x3f3f3f3f;
    int ans, k = INF;
    int main() {
    int n, t, a, b, c;
    scanf("%d%d", &n, &t);
    for (int i = ; i <= n; i++) {
    scanf("%d%d", &a, &b);
    if (a >= t) {
    c = a - t;
    } else {
    c = ((a - t) % b + b) % b;
    }
    if (c < k) {
    k = c;
    ans = i;
    }
    }
    printf("%d\n", ans);
    return ;
    }

    最后一个取余忘了,然后就被hack......甚是无语

B .Serval and Toy Bricks

pro:给出三视图每一列的高度,俯视图有点特殊,只有0或1,求俯视图每一格的高度

sol:结果不唯一,对于俯视图每一格,找到对应的左视图和前视图,取其中高度小的就必能配成正确的俯视图

  • 贪心

    #include "bits/stdc++.h"
    using namespace std;
    const int MAXN = ;
    int mp[MAXN][MAXN];
    int f[MAXN], l[MAXN];
    int main() {
    int n, m, k;
    scanf("%d%d%d", &n, &m, &k);
    for (int i = ; i <= m; i++)
    scanf("%d", &f[i]);
    for (int i = ; i <= n; i++)
    scanf("%d", &l[i]);
    for (int i = ; i <= n; i++) {
    for (int j = ; j <= m; j++) {
    scanf("%d", &mp[i][j]);
    if (mp[i][j]) mp[i][j] = min(f[j], l[i]);
    }
    }
    for (int i = ; i <= n; i++) {
    for (int j = ; j <= m; j++)
    printf("%d ", mp[i][j]);
    puts("");
    }
    return ;
    }

C .Serval and Parenthesis Sequence

pro:给出一个括号串,其中一部分被用'?'代替,补全括号串,使得括号串除自身以外每个前缀串都不是合法括号串,但是自身是合法括号串,若无法补全,输出":(";

sol:还是贪心,因为要补成合法括号串,所以左括号个数为(|s| / 2)个,从左往右扫,遇到'?'如果能补左括号就补左括号,补不了左括号再补右括号,如果还没到末尾就合法了,输出":(",如果到末尾还不是合法括号串,也输出":(",否则输出补好的串。CF贪心的题好多啊

  • 贪心

    #include "bits/stdc++.h"
    using namespace std;
    const int MAXN = 3e5 + ;
    char s[MAXN];
    int n, k, l;
    int main() {
    scanf("%d%s", &n, &s);
    k = n >> ;
    for (int i = ; i < n; i++)
    if (s[i] == '(') k--;
    for (int i = ; i < n; i++) {
    if (s[i] == '?') {
    if (k > ) {
    s[i] = '(';
    k--;
    } else {
    s[i] = ')';
    }
    }
    }
    for (int i = ; i < n - ; i++) {
    if (s[i] == '(') {
    l++;
    } else {
    l--;
    }
    if (l <= ) {
    puts(":(");
    return ;
    }
    }
    if (s[n - ] == ')') {
    l--;
    } else {
    l++;
    }
    if (l == ) {
    puts(s);
    } else {
    puts(":(");
    }
    return ;
    }

D . Serval and Rooted Tree

pro:给出一棵树,除叶子节点外每个节点有一个属性,0表示该节点的值等于子节点中最大值,1表示该节点的值等于子节点中最小值,将1到k填入k个子节点,使得根节点值最大。

sol:树形dp + dfs,dfs(i) 表示叶子节点的个数减去i节点的最大值,所以用叶子节点个数减dfs(i)就是i节点最大值,至于树形dp那一块,看代码应该能懂了。

  • 树形dp + 深度优先搜索 + 好像也有点贪心在里面吧

    #include "bits/stdc++.h"
    using namespace std;
    const int MAXN = 3e5 + ;
    const int INF = 0x3f3f3f3f;
    vector<int> v[MAXN];
    int arr[MAXN], val[MAXN];
    int leaf;
    int dfs(int k) {
    if (v[k].empty()) return ;
    if (arr[k] == ) {
    int mn = INF;
    for (int i = ; i < v[k].size(); i++)
    mn = min(mn, dfs(v[k][i]));
    return mn;
    } else {
    int sum = ;
    for (int i = ; i < v[k].size(); i++)
    sum += dfs(v[k][i]);
    return sum + v[k].size() - ;
    }
    }
    int main() {
    int n, k;
    scanf("%d", &n); leaf = n;
    for (int i = ; i <= n; i++)
    scanf("%d", &arr[i]);
    for (int i = ; i <= n; i++) {
    scanf("%d", &k);
    if (v[k].empty()) leaf--;
    v[k].push_back(i);
    }
    printf("%d\n", leaf - dfs());
    return ;
    }

    思路来源于今年蓝桥杯省赛的一道求雨题,不过这两题比赛当场都没能完成。都是比赛结束之后才想通的。继续努力

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

  1. CF 551 E GukiZ and GukiZiana

    https://codeforces.com/contest/551/problem/E 分块真强. 题意就是1.区间加,2.询问整个区间中,最远的两个x的距离. 分块,然后,每次找位子用二分找即可. ...

  2. CF 551 D.Serval and Rooted Tree 树形DP

    传送门:http://codeforces.com/contest/1153/problem/D 思路: 这道题想了一天,突发奇想,就是维护每个点两个值,第几大和第几小,就可以有传递性了. #incl ...

  3. CF 题目选做

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

  4. CF 219D 树形DP

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

  5. LeetCode:学生的出勤记录|【551】

    LeetCode:学生的出勤记录|[551] 题目描述 给定一个字符串来代表一个学生的出勤纪录,这个纪录仅包含以下三个字符: 'A' : Absent,缺勤 'L' : Late,迟到 'P' : P ...

  6. 跟着xiaoxin巨巨做cf

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

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

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

  8. 洛谷P3367 【模板】并查集

    P3367 [模板]并查集 293通过 551提交 题目提供者HansBug 标签 难度普及- 提交  讨论  题解 最新讨论 不知道哪错了 为啥通不过最后三个节点 题解 不懂为什么MLE 最后一个数 ...

  9. Miaomiao's Geometry

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

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

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

随机推荐

  1. Dynamics CRM - 为 Form 或者字段设置 Error Notification

    在 Dynamics CRM 开发中,我们一般要利用 JS 来做一些数据验证的功能,我们也需要将验证结果显示出来,比起直接 alert 出信息来提示用户的方式,CRM 提供了更加美观和人性化的方式来通 ...

  2. JavaScript 之 DOM 与 BOM

    DOM是文档对象模型,用来获取或设置文档中标签的属性,例如获取或者设置input表单的value值. 由于DOM的操作对象是文档(Document),所以dom和浏览器没有直接关系. BOM是浏览器对 ...

  3. JAVA中常用的异常处理情况

    1.java.lang.nullpointerexception程序遇上空指针 这个异常大家肯定都经常遇到,异常的解释是"程序遇上了空指针",简单地说就是调用了未经初始化的对象或者 ...

  4. VC调用VB写的COM

    VB. 步骤: 1.创建类库:类库的创建必须分为接口和实现类:给外面提供的是COM接口: 创建了接口和类之后还要创建"Guid",这个在"工具->创建GUID&qu ...

  5. 用数组来实现Stack

    1:Stack特点 stack:栈,是一种特殊的数据结构,有着先入后出的特点(first in last out).stack中栈底始终不变,只有一端能变化.栈顶在有数据push的时候增大,有数据po ...

  6. 干货 | 调用AI api 实现网页文字朗读

    京东云上提供了足够多的人工智能api,并且都使用了http的方式进行了封装,用户可以方便在自己的系统中接入京东云的ai能力.今天就是介绍一下如何编写很少的代码就能使用京东云的语音合成api在网页中实现 ...

  7. storm 机制

    storm基础系列之二----zookeeper的作用 https://www.cnblogs.com/xyang/p/5643745.html Zookeeper+Storm集群搭建 https:/ ...

  8. C# 基础Array

    一.Array的作用 连续定义多个相同类型的变量,比如我定义1000个学生的学生年龄,int[] age = new int[1000];不需要慢慢的一个一个变量的定义,数组是不是很方便. 需要注意的 ...

  9. MyBatis从入门到精通(第6章):MyBatis 高级查询->6.1.1高级结果映射之一对一映射

    jdk1.8.MyBatis3.4.6.MySQL数据库5.6.45.IntelliJ IDEA 2019.2.4 本章主要包含的内容为 MyBatis 的高级结果映射,主要处理数据库一对一.一对多的 ...

  10. UML-逻辑架构和包图-概述

    回顾前几章学习了用例模型,本章开始学习设计模型.