题目传送门

A .Yet Another Dividing into Teams

sol:原先是用比较复杂的方法来解的,后来学弟看了一眼,发现不是1就是2,当出现两个人水平相差为1就分成两组,1组全是奇数,1组全是偶数,必然符合题意。

  • 思维

    #include "bits/stdc++.h"
    using namespace std;
    #define debug puts("what the fuck");
    typedef long long LL;
    typedef pair<int, int> PII;
    const int MAXN = ;
    bool vis[MAXN];
    int main() {
    int t, n, m;
    scanf("%d", &t);
    while (t--) {
    scanf("%d", &n);
    bool ok = true;
    memset(vis, false, sizeof(vis));
    for (int i = ; i <= n; i++) {
    scanf("%d", &m);
    vis[m] = true;
    if (vis[m - ] || vis[m + ]) ok = false;
    }
    if (ok) puts("");
    else puts("");
    }
    return ;
    }

B. Books Exchange

sol:很裸的并查集,i和p[i]属于同一个集合,求每个点所在集合的大小

  • 并查集

    #include "bits/stdc++.h"
    using namespace std;
    #define debug puts("what the fuck");
    typedef long long LL;
    typedef pair<int, int> PII;
    const int MAXN = 2e5 + ;
    int pre[MAXN], cnt[MAXN];
    int find(int i) {
    if (pre[i] == i) return i;
    return pre[i] = find(pre[i]);
    }
    int main() {
    int t, n, m;
    scanf("%d", &t);
    while (t--) {
    scanf("%d", &n);
    for (int i = ; i <= n; i++) {
    cnt[i] = ;
    pre[i] = i;
    }
    for (int i = ; i <= n; i++) {
    scanf("%d", &m);
    int u = find(i);
    int v = find(m);
    if (u != v) {
    pre[u] = v;
    cnt[v] += cnt[u];
    }
    }
    for (int i = ; i <= n; i++)
    printf("%d ", cnt[find(i)]);
    puts("");
    }
    return ;
    }

C1. Good Numbers (easy version)

sol:由于n比较小,所以我们可以暴力罗列good number,pow(3, 10)已经大于n的最大范围10000,所以罗列到3的10次方够了,再组合一下,排序后用二分去搜就好了。

  • 暴力组合

    #include "bits/stdc++.h"
    using namespace std;
    #define debug puts("what the fuck");
    typedef long long LL;
    typedef pair<int, int> PII;
    int p[] = {};
    vector<int> v;
    void init() {
    for (int i = ; i <= ; i++)
    p[i] = * p[i - ];
    for (int i = ; i <= ( << ); i++) {
    int sum = ;
    for (int j = ; j <= ; j++)
    if (i & ( << j)) sum += p[j];
    v.push_back(sum);
    }
    }
    int main() {
    int t, n;
    scanf("%d", &t);
    init();
    sort(v.begin(), v.end());
    while (t--) {
    scanf("%d", &n);
    printf("%d\n", *lower_bound(v.begin(), v.end(), n));
    }
    return ;
    }

C2. Good Numbers (hard version)

sol:细看这题感觉和进制有关,把n转成3进制后找到第一个大于等于n并且所以三进制位不为2的数;

  • 进制

    #include "bits/stdc++.h"
    using namespace std;
    #define debug puts("what the fuck");
    typedef long long LL;
    typedef pair<int, int> PII;
    int p[];
    int main() {
    int t;
    LL n, pos;
    scanf("%d", &t);
    while (t--) {
    scanf("%lld", &n);
    memset(p, , sizeof(p));
    pos = ;
    while (n) {
    p[pos++] = n % ;
    n /= ;
    }
    int k = pos - ;
    while (k > && p[k] != ) k--; // 从高位往低位搜找到第一个2
    for (int i = k - ; i >= ; i--) p[i] = ; // 第k位加1,那么k之前的位可以全部为0了,一定不会小于n
    while (p[k] == ) { //进位
    p[k] = ;
    p[++k] ++;
    }
    pos = max(pos, k + 1LL);
    LL sum = , pp = ;
    for (int i = ; i < pos; i++) {
    if (p[i] == ) sum += pp;
    pp *= ;
    }
    printf("%lld\n", sum);
    }
    return ;
    }

D. Too Many Segments

sol:用差分确定覆盖每个点的线段有多少条,对于点i,如果覆盖的线段数量大于k,删掉覆盖该点的右端点最远的线段,可以用优先队列找这样的线段。就是需要两个排序方式。

  • 贪心,差分

    #include "bits/stdc++.h"
    using namespace std;
    #define debug puts("what the fuck");
    typedef long long LL;
    typedef pair<int, int> PII;
    const int MAXN = 2e5 + ;
    struct Seg {
    int l, r;
    int index;
    friend bool operator < (Seg a, Seg b) {return a.r < b.r;}
    } a[MAXN];
    priority_queue<Seg> que;
    bool cmp(Seg a, Seg b) {return a.l < b.l;}
    vector<int> ans;
    int cnt[MAXN], pos, sum;
    int main() {
    int n, m;
    scanf("%d%d", &n, &m);
    for (int i = ; i <= n; i++) {
    scanf("%d%d", &a[i].l, &a[i].r);
    a[i].index = i;
    }
    sort(a + , a + + n, cmp);
    for (int i = ; i <= n; i++) {
    while (pos < a[i].l) sum += cnt[++pos];
    que.push(a[i]);
    sum ++, cnt[a[i].r + ] --;
    if (sum > m) {
    sum --;
    Seg s = que.top();
    que.pop();
    cnt[s.r + ] ++;
    ans.push_back(s.index);
    }
    }
    printf("%d\n", ans.size());
    for (auto index : ans) printf("%d ", index);
    return ;
    }

E. By Elevator or Stairs?

sol:dp,dp[0][i]表示从a[i]到1的最少时间,dp[1][i]表示从b[i]到1的最少时间。代码中直接把a、b数组当dp[0]和dp[1]来用了;

  • 动态规划

    #include "bits/stdc++.h"
    using namespace std;
    #define debug puts("what the fuck");
    typedef long long LL;
    typedef pair<int, int> PII;
    const int MAXN = 2e5 + ;
    int a[MAXN], b[MAXN];
    int main() {
    int n, c;
    scanf("%d%d", &n, &c);
    a[] = , b[] = c;
    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++) {
    a[i] += min(a[i - ], b[i - ]);
    b[i] += min(a[i - ] + c, b[i - ]);
    printf("%d ", min(a[i], b[i]));
    }
    return ;
    }

F. Maximum Weight Subset

sol:树形dp,dp[u][dep]表示u子树中距离u最近的选取点离u的距离不小于dep的最大权重。要注意的是合并的时候两颗子树间的选取点距离也不能小于等于k;

  • 树形dp

    #include "bits/stdc++.h"
    using namespace std;
    #define debug puts("what the fuck");
    typedef long long LL;
    typedef pair<int, int> PII;
    const int MAXN = ;
    int w[MAXN];
    int dp[MAXN][MAXN];
    vector<int> edge[MAXN];
    int n, k;
    void dfs(int u, int fa) {
    for (auto v : edge[u]) {
    if (v == fa) continue;
    dfs(v, u);
    }
    dp[u][] = w[u];
    for (auto v : edge[u]) {
    if (v == fa) continue;
    dp[u][] += dp[v][k];
    }
    for (int dep = ; dep <= k; dep++) {
    for (auto v : edge[u]) {
    if (v == fa) continue;
    int sum = dp[v][dep - ];
    for (auto other : edge[u]) {
    if (other == fa || other == v) continue;
    sum += dp[other][max(dep - , k - dep)];
    }
    dp[u][dep] = max(dp[u][dep], sum);
    }
    }
    for (int i = k - ; i >= ; i--) dp[u][i] = max(dp[u][i], dp[u][i + ]);
    }
    int main() {
    scanf("%d%d", &n, &k);
    for (int i = ; i <= n; i++) scanf("%d", &w[i]);
    for (int i = ; i <= n; i++) {
    int u, v;
    scanf("%d%d", &u, &v);
    edge[u].push_back(v);
    edge[v].push_back(u);
    }
    dfs(, -);
    printf("%d\n", dp[][]);
    return ;
    }

    官方题解里vector太多了,看的好懵逼。提交最后解释了一下为什么复杂度是O(n^3)不是O(n^4),但是我看着还是感觉复杂度是O(n^4)

——————————————————————————————————————————————————————————————

第一次把一场CF所有题都补出来,开心

CF-595的更多相关文章

  1. cf 595 补题

    1.B2   Books Exchange (hard version) 题意:有n(1~n)个孩子看书,定义一个数组,记录了每个孩子看完

  2. ORA-00494: enqueue [CF] held for too long (more than 900 seconds) by 'inst 1, osid 5166'

    凌晨收到同事电话,反馈应用程序访问Oracle数据库时报错,当时现场现象确认: 1. 应用程序访问不了数据库,使用SQL Developer测试发现访问不了数据库.报ORA-12570 TNS:pac ...

  3. 基于小脚丫的ADC081S101 电压采集595数码管显示

    RTL结构图 采集模块运用SPI 通讯 MISO方式收集数据 module ad_collect(input sddata,input rst_n,output reg cs,output reg s ...

  4. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  5. cf Round 613

    A.Peter and Snow Blower(计算几何) 给定一个点和一个多边形,求出这个多边形绕这个点旋转一圈后形成的面积.保证这个点不在多边形内. 画个图能明白 这个图形是一个圆环,那么就是这个 ...

  6. ARC下OC对象和CF对象之间的桥接(bridge)

    在开发iOS应用程序时我们有时会用到Core Foundation对象简称CF,例如Core Graphics.Core Text,并且我们可能需要将CF对象和OC对象进行互相转化,我们知道,ARC环 ...

  7. [Recommendation System] 推荐系统之协同过滤(CF)算法详解和实现

    1 集体智慧和协同过滤 1.1 什么是集体智慧(社会计算)? 集体智慧 (Collective Intelligence) 并不是 Web2.0 时代特有的,只是在 Web2.0 时代,大家在 Web ...

  8. CF memsql Start[c]UP 2.0 A

    CF memsql Start[c]UP 2.0 A A. Golden System time limit per test 1 second memory limit per test 256 m ...

  9. CF memsql Start[c]UP 2.0 B

    CF memsql Start[c]UP 2.0 B B. Distributed Join time limit per test 1 second memory limit per test 25 ...

  10. CF #376 (Div. 2) C. dfs

    1.CF #376 (Div. 2)    C. Socks       dfs 2.题意:给袜子上色,使n天左右脚袜子都同样颜色. 3.总结:一开始用链表存图,一直TLE test 6 (1)如果需 ...

随机推荐

  1. [C/C++]'fopen': This function or variable may be unsafe

    这个错误也算比较常见吧,当然这个与代码无关,是编译器的问题,主要是VS中出现的,因为微软方面认为fopen函数是不安全的,于是自己搞了一套fopen_s的函数来代替,用前面一个的话编译器是会出错的,所 ...

  2. no.10京东咚咚架构演讲读后感

    京东之与旺旺相当于淘宝,他们都是服务于买家和卖家的沟通.京东咚咚的功能比较简单,实现了一个 IM 的基本功能,接入.互通消息和状态. 另外还有客服功能,就是顾客接入咨询时的客服分配,按轮询方式把顾客分 ...

  3. 远程过程调用——RPC

    https://www.jianshu.com/p/5b90a4e70783 清晰明了

  4. Python说文解字_Python之多任务_02

    第三部分:Semaphore控制进入数量的锁 有时候可能需要运行多个工作线程同时访问一个资源,但要限制总数.例如,连接池支持同时连接,但是数目可能是固定的,或者一个网络应用可能支持固定数据的并发下载. ...

  5. JavaScript之递归

    什么是递归? 程序调用自身的编程技巧称为递归( recursion).递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量 . 递归的能力在于用有限的语句来定义对象的 ...

  6. github访问过慢解决

    为了更加愉快地使用全球最大同性交友网站上的优质资源,我们来做一些简单的本机上的调整. 通过查看下载链接,能够发现最终被指向到Amazon的服务器(http://github-cloud.s3.amaz ...

  7. 吴裕雄--天生自然MySQL学习笔记:MySQL 临时表

    MySQL 临时表在我们需要保存一些临时数据时是非常有用的.临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间. MySQL临时表只在当前连接可见,如果使用PHP脚本来创建My ...

  8. ftp限制

    /etc/hosts.deny /etc/vsftpd/user_list 从2.3.5之后,vsftpd增强了安全检查,如果用户被限定在了其主目录下,则该用户的主目录不能再具有写权限了!如果检查发现 ...

  9. 关于scala工程结构(使用sbt)

    scala_project:常用目录结构: |lib:手动添加依赖包 |project | |build.properties:build的版本号,可以不写,会自动下载 | |plugins.sbt: ...

  10. 微信官方小程序示例demo 微信开发者工具打开不显示云开发按钮

    如果直接打开官方的demo,微信开发者工具上是不显示云开发按钮的. 是因为默认appid是测试号.要换成一个正式appid就会显示云开发按钮了. 分享一个朋友的人工智能教程.零基础!通俗易懂!风趣幽默 ...