A. Stickers and Toys

考虑尽量先买\(max(s, t)\)个里面单独的。那么如果\(s + t > n\)那么\(s + t - n\)的部分就该把\(min(s, t)\)踢出来,这些多的只能合并到另外一个上面去,所以答案就是:$ max(s, t) - (s + t - n) + 1$。

#include <cstdio>
#include <iostream>
#include <cmath>
using namespace std;
int n, s, t;
int main(){
int T; scanf("%d", &T);
while(T--){
scanf("%d%d%d", &n, &s, &t);
printf("%d\n", max(s, t) - (s + t - n) + 1);
}
return 0;
}

B. Letters Shop

二分答案。答案符合区间包括性(单调性),若\([1, x]\)可行,那么\([1, y] (x <= y <= n)\)必然也可行。

预处理前缀和,\(check()\)的时间复杂度可以降到\(O(26)\),那么总共程序的时间复杂度为\(O(mlogn)\)。

#include <cstdio>
#include <iostream>
#include <cstring>
using namespace std;
const int N = 200010, M = 50010;
char s[N], t[N];
int n, m, sum[N][26], g[26], len;
//[1, x]这段可不可行
bool inline check(int x){
for(int i = 0; i < 26; i++)
if(sum[x][i] < g[i]) return false; return true;
}
int main(){
scanf("%d%s%d", &n, s + 1, &m);
for(int i = 1; i <= n; i++){
for(int j = 0; j < 26; j++) sum[i][j] = sum[i - 1][j];
sum[i][s[i] - 'a']++;
}
for(int i = 1; i <= m; i++) {
for(int j = 0; j < 26; j++) g[j] = 0;
scanf("%s", t + 1);
len = strlen(t + 1);
for(int i = 1; i <= len; i++) g[t[i] - 'a']++; int l = 1, r = n;
while(l < r){
int mid = (l + r) >> 1;
if(check(mid)) r = mid;
else l = mid + 1;
}
printf("%d\n", r);
}
return 0;
}

C. Vasya And Array

由于发现在线做法需要分类讨论,懒癌晚期就把信息进行了排序\(qwq\)。

不难发现,\(NO\)的情况就是\(0\)的信息属于\(1\)的子序列。但是如果直接处理,就有多种冲突可能,\(check\)就需要分类讨论了。先处理\(1\)的数据,再处理\(0\)的数据,就只需要检查\(0\)是不是子区间就可以了。

关于方案,设\(f[i]\)为\(i\)和\(i + 1\)的关系(不变还是递减),这样只需要顺次维护即可。

#include <cstdio>
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
const int N = 1010, M = 1010;
int n, m, f[N];
//f[i] 表示 i 和 i + 1 的关系
struct Node{
int l, r, t;
}e[M];
bool inline cmp(Node x, Node y){
return x.t > y.t;
}
bool inline check(int l, int r, int t){
for(int i = l; i < r; i++)
if(f[i] == -1 || f[i] == t) return true;
return false;
}
int main(){
memset(f, -1, sizeof f);
scanf("%d%d", &n, &m);
for(int i = 1; i <= m; i++){
int t, l, r; scanf("%d%d%d", &t, &l, &r);
e[i] = (Node){l, r, t}; }
sort(e + 1, e + 1 + m, cmp);
for(int i = 1; i <= m; i++){
int l = e[i].l, r = e[i].r, t = e[i].t;
if((!check(l, r, t))) { puts("NO"); return 0; }
else for(int i = l; i < r; i++)
if(f[i] == -1)f[i] = t;
}
int last = n; printf("YES\n%d ", n);
for(int i = 1; i < n; i++)
if(f[i]) printf("%d ", last);
else printf("%d ", --last); return 0;
}

E. Tree Painting

换根法。发现是一颗树。每次扩展的时候,假设时间倒流,发现是一个逐层逆推递进的过程。

对于任意两点\((u, v)\),除了他们的路径上的贡献外,所有外面的扩展是相同的。

  • \(f[u][0]\)为该点向下扩展的花费,包括\(u\)的花费

  • \(f[u][1]\)为改点向上扩展的花费,不包括\(u\)的花费

  • \(size[u]\)为以\(u\)为子树的大小

状态转移方程:

\(f[u][0] = size[u] + \sum_{(u , v)} f[v][0]\)

\(f[v][1] = (n - size[v]) + f[u][1] + (f[u][0] - size[u] - f[v][0]) (u , v)\)

答案:

\(max\{f[i][0] + f[i][1] + (n - size[i])\} (1 <= i <= n)\)

这里可以理解为两者均是时间倒流的产物,第一次扩展是先扩展下面的,所以需要计算首次合并。

#include <cstdio>
#include <iostream>
#include <cmath>
using namespace std;
const int N = 200010, M = N << 1;
typedef long long LL;
int n, head[N], numE = 0;
LL f[N][2], size[N];
struct Edge{
int next, to;
}e[M];
void addEdge(int from, int to){
e[++numE].next = head[from];
e[numE].to = to;
head[from] = numE;
}
void dfs_(int u, int fa){
size[u] = 1;
for(int i = head[u]; i; i = e[i].next){
int v = e[i].to;
if(v == fa) continue;
dfs_(v, u);
size[u] += size[v];
f[u][0] += f[v][0];
}
f[u][0] += size[u];
}
void dfs(int u, int fa){
for(int i = head[u]; i; i = e[i].next){
int v = e[i].to;
if(v == fa) continue;
f[v][1] = (n - size[v]) + f[u][1] + (f[u][0] - size[u] - f[v][0]);
dfs(v, u);
}
}
int main(){
scanf("%d", &n);
for(int i = 1; i < n; i++){
int u, v; scanf("%d%d", &u, &v);
addEdge(u, v); addEdge(v, u);
}
dfs_(1, 0);
dfs(1, 0);
LL ans = -1;
for(int i = 1; i <= n; i++)
ans = max(ans, f[i][0] + f[i][1] + (n - size[i]));
printf("%lld\n", ans);
return 0;
}

Codeforces Edu Round 67 A-C + E的更多相关文章

  1. Codeforces Beta Round #67 (Div. 2)

    Codeforces Beta Round #67 (Div. 2) http://codeforces.com/contest/75 A #include<bits/stdc++.h> ...

  2. 【计算几何】 Codeforces Beta Round #67 (Div. 2) E. Ship's Shortest Path

    读懂题意其实是模板题.就是细节略多. #include<cstdio> #include<cmath> #include<algorithm> using name ...

  3. Codeforces Beta Round #67 (Div. 2)C. Modified GCD

    C. Modified GCD time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...

  4. Educational Codeforces Round 67 D. Subarray Sorting

    Educational Codeforces Round 67 D. Subarray Sorting 传送门 题意: 给出两个数组\(a,b\),现在可以对\(a\)数组进行任意次排序,问最后能否得 ...

  5. Educational Codeforces Round 67

    Educational Codeforces Round 67 CF1187B Letters Shop 二分 https://codeforces.com/contest/1187/submissi ...

  6. Codeforces Beta Round #80 (Div. 2 Only)【ABCD】

    Codeforces Beta Round #80 (Div. 2 Only) A Blackjack1 题意 一共52张扑克,A代表1或者11,2-10表示自己的数字,其他都表示10 现在你已经有一 ...

  7. Codeforces Beta Round #62 题解【ABCD】

    Codeforces Beta Round #62 A Irrational problem 题意 f(x) = x mod p1 mod p2 mod p3 mod p4 问你[a,b]中有多少个数 ...

  8. Codeforces Beta Round #83 (Div. 1 Only)题解【ABCD】

    Codeforces Beta Round #83 (Div. 1 Only) A. Dorm Water Supply 题意 给你一个n点m边的图,保证每个点的入度和出度最多为1 如果这个点入度为0 ...

  9. Codeforces Beta Round #13 C. Sequence (DP)

    题目大意 给一个数列,长度不超过 5000,每次可以将其中的一个数加 1 或者减 1,问,最少需要多少次操作,才能使得这个数列单调不降 数列中每个数为 -109-109 中的一个数 做法分析 先这样考 ...

随机推荐

  1. linux nf_conntrack 连接跟踪机制

    PRE_ROUTING和LOCAL_OUT点可以看作是整个netfilter的入口,而POST_ROUTING和LOCAL_IN可以看作是其出口; 报文到本地:PRE_ROUTING----LOCAL ...

  2. C++的四种强制转型形式:

    C++同时提供了四种新的强制转型形式(通常称为新风格的或C++风格的强制转型): const_cast(expression)dynamic_cast(expression)reinterpret_c ...

  3. 基于FFmpeg的Dxva2硬解码及Direct3D显示(二)

    解析视频源 目录 解析视频源 获取视频流 解析视频流 说明:这篇博文分为"获取视频流"和"解析视频流"两个部分,使用的是FFmpeg4.1的版本,与网上流传的低 ...

  4. cephfs根据存储池显示df容量

    前言 如果用cephfs比较多,应该都知道,在cephfs的客户端进行mount以后,看到的容量显示的是集群的总的容量,也就是你的总的磁盘空间是多少这个地方显示的就是多少 这个一直都是这样显示的,我们 ...

  5. ceph的ISCSI GATEWAY

    前言 最开始接触这个是在L版本的监控平台里面看到的,有个iscsi网关,但是没看到有类似的介绍,然后通过接口查询到了一些资料,当时由于有比较多的东西需要新内核,新版本的支持,所以并没有配置出来,由于内 ...

  6. SSL加密原理

    对称加密算法 对称加密算法,同一个密钥可以同时用作信息的加密和解密,这种加密方法称为对称加密,也称为单密钥加密. 非对称加密算法 非对称加密算法(RSA)是内容加密的一类算法,它有两个秘钥:公钥与私钥 ...

  7. powershell过杀软工具-xencrypt

           在红队攻击中,绕杀软是一个比较常见的技术.对于绕过杀软的方法,有基于黑白名单的,有基于shellloader的,也有基于加密与混淆的.最近在发现了这样一款过杀软的工具,推荐给有缘人,嘻嘻 ...

  8. 分布式监控系统之Zabbix主动、被动及web监控

    前文我们了解了zabbix的网络发现功能,以及结合action实现自动发现主机并将主机添加到zabbix hosts中,链接指定模板进行监控:回顾请参考https://www.cnblogs.com/ ...

  9. 面试大厂必看!就凭借这份Java多线程和并发面试题,我拿到了字节和美团的offer!

    最近好多粉丝私信我说在最近的面试中老是被问到多线程和高并发的问题,又对这一块不是很了解,很简单就被面试官给问倒了,被问倒的后果当然就是被刷下去了,因为粉丝要求,我最近也是花了两天时间 给大家整理了这一 ...

  10. 你了解ABBYY FineReader 14么?

    有没有一款是能够同时处理纸质文档和个类型PDF的一站式解决方案?答案是肯定的,ABBYY FineReader 14集合了强大的光学字符识别(OCR)以及 PDF 查看和编辑功能.不仅能够高效识别图片 ...