前记

眼看他起高楼;眼看他宴宾客;眼看他楼坍了。

比赛历程

开考前一分钟还在慌里慌张地订正上午考试题目。

“诶这个数位dp哪里见了鬼了???”瞥了眼时间,无奈而迅速地关去所有其他窗口,临时打了一个缺省源。

A. Phone Numbers

那么就是模拟。

 #include<bits/stdc++.h>

 int n,x;
char s[]; int read()
{
char ch = getchar();
int num = ;
bool fl = ;
for (; !isdigit(ch); ch=getchar())
if (ch=='-') fl = ;
for (; isdigit(ch); ch=getchar())
num = (num<<)+(num<<)+ch-;
if (fl) num = -num;
return num;
}
int main()
{
n = read();
scanf("%s",s);
for (int i=; i<n; i++)
if (s[i]=='') x++;
printf("%d\n",std::min(x, n/));
return ;
}

B. Maximum Sum of Digits

结论题。构造尽可能多的999……

 #include<bits/stdc++.h>
typedef long long ll; ll n,num; long long read()
{
char ch = getchar();
long long num = ;
bool fl = ;
for (; !isdigit(ch); ch=getchar())
if (ch=='-') fl = ;
for (; isdigit(ch); ch=getchar())
num = (num<<)+(num<<)+ch-;
if (fl) num = -num;
return num;
}
ll calc(ll x)
{
ll ret=;
for (; x; x/=) ret += x%;
return ret;
}
int main()
{
n = read(), num = ;
while (num < n) num = num*+;
num /= ;
printf("%lld\n",calc(num)+calc(n-num));
return ;
}

C. Maximum Subrectangle

有点意思的题:找一个面积最大,权值和小于lim的矩阵。但是这个矩阵有个特殊性质:它不是没有规律地给定,而是由两个数列相乘构造而来。n<=2000.

做法一:

先枚举一个维,将这个维所有的段长和元素和都存下来,然后sort一下。另一维枚举,二分寻找最大能够匹配的段。

时间复杂度$O(n^2log_2n)$

做法二:

然而上面一个做法的浪费在于存下所有的段。注意到这个决策是单调的,对于长度相同的段,只有元素和最小的是有用的。那么对于两个维,都记录这个最小值。最后分别枚举两维的长度时直接匹配。

时间复杂度$O(n^2)$

 #include<bits/stdc++.h>
const int maxn = ; struct node
{
int a,b;
bool operator < (node x) const
{
if (a < x.a) return a < x.a;
return b < x.b;
}
}sv[];
int a[maxn],b[maxn],n,m,lim;
int sa[maxn],sb[maxn];
int mna[maxn],mnb[maxn];
int cnt,ans; int read()
{
char ch = getchar();
int num = ;
bool fl = ;
for (; !isdigit(ch); ch=getchar())
if (ch=='-') fl = ;
for (; isdigit(ch); ch=getchar())
num = (num<<)+(num<<)+ch-;
if (fl) num = -num;
return num;
}
int main()
{
memset(mna, 0x3f3f3f3f, sizeof mna);
memset(mnb, 0x3f3f3f3f, sizeof mnb);
n = read(), m = read();
for (int i=; i<=n; i++) a[i] = read(), sa[i] = sa[i-]+a[i];
for (int i=; i<=m; i++) b[i] = read(), sb[i] = sb[i-]+b[i];
lim = read();
for (int i=; i<=n; i++)
for (int j=i; j<=n; j++)
mna[j-i+] = std::min(mna[j-i+], sa[j]-sa[i-]);
for (int i=; i<=m; i++)
for (int j=i; j<=m; j++)
mnb[j-i+] = std::min(mnb[j-i+], sb[j]-sb[i-]);
for (int i=; i<=n; i++)
for (int j=; j<=m; j++)
if (1ll*mna[i]*mnb[j] <= 1ll*lim)
ans = std::max(ans, i*j);
printf("%d\n",ans);
return ;
}

D. Social Circles

开场时候原本就打算手速D的,又恰巧总榜上D被秒掉了。于是弃了BC就去看D……

想了好久也没有什么靠谱做法,这时t老师6分钟就写完了D,瞬间心态崩坏。

想啊想啊,是个贪心?图论?然而一点没往结论题方向想。

没办法只能转回头去做C。脑子里一团浆糊,什么也想不进去。

最后是等到XCW在1:09大力猜结论过了pretest机房才大队人马过D。

大致题意:有n个人,每个人要求自己左边有li张空椅子;右边有ri张空椅子。可以把不同的人任意分组。问最小需要的总椅子数量。

结论是:这些人的左右手要求是可以互换的。那么就是排序之后取max。

好像现在官方题解还没出来?那么这个结论我也没法证明……

 #include<bits/stdc++.h>
const int maxn = ; int n,a[maxn],b[maxn];
long long ans; 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]);
std::sort(a+, a+n+);
std::sort(b+, b+n+);
for (int i=; i<=n; i++) ans += std::max(a[i], b[i]);
printf("%lld\n",ans);
return ;
}

E. Sergey and Subway

花CD的时间太久了……E题题意直接去问同学了。

然而刚开始一段时间把题意理解错了。

大致题意:现在有一颗树,边权均为1。每次操作将原树上距离为2的点,在新树上连接一条边权为1的边。进行操作直到不能再操作为止。询问新树两两点对距离和。

首先是结论:原树上长度为$d$的路径,在新树上长度变为$\frac{d+1}{2}(向下取整)$。

这个比较容易理解:对于长度为2的路径,长度变为1;长度为1的路径,长度不变;然后任意一条路径都可以视作由2、1的路径拼接而成。

第一感觉是点分?但是一看时间不大对了直接去求助t老师了。

t老师:不用点分……一开始我写了一个很复杂的上下dp。这个题超傻逼的,只要枚举边计算贡献。然后计奇数路径条数。深度奇偶性不同的就是奇数路径。

哇好有道理的样子哦。想了想就开始码(然而中间还码错了点小细节耽搁一会),然后就愉快地过掉了。(但是毕竟还是手速太慢,E题最后只有1008的分)

 #include<bits/stdc++.h>
const int maxn = ; long long ans;
int n,tot[maxn],dep[maxn],sum[];
int edges[maxn<<],nxt[maxn<<],head[maxn],edgeTot; int read()
{
char ch = getchar();
int num = ;
bool fl = ;
for (; !isdigit(ch); ch=getchar())
if (ch=='-') fl = ;
for (; isdigit(ch); ch=getchar())
num = (num<<)+(num<<)+ch-;
if (fl) num = -num;
return num;
}
void addedge(int u, int v)
{
edges[++edgeTot] = v, nxt[edgeTot] = head[u], head[u] = edgeTot;
edges[++edgeTot] = u, nxt[edgeTot] = head[v], head[v] = edgeTot;
}
void dfs(int x, int fa)
{
tot[x] = , dep[x] = dep[fa]+, sum[dep[x]&]++;
for (int i=head[x]; i!=-; i=nxt[i])
{
int v = edges[i];
if (v!=fa){
dfs(v, x);
tot[x] += tot[v];
long long t = 1ll*tot[v]*(n-tot[v]);
ans += t;
}
}
}
int main()
{
memset(head, -, sizeof head);
n = read();
for (int i=; i<n; i++) addedge(read(), read());
dfs(, );
ans += 1ll*sum[]*sum[];
printf("%lld\n",ans/);
return ;
}

xor则是发现了点分FFT的写法,恰巧以前度教出过一道类似的题,于是机房大队人马搬来自己代码争先恐后地过了pretest。

【后话:除了我和xor其他人都FST了;反正WA、RE、TLE全齐了】

后记

哎,暑假一共就打了两场,打得还非常差。现在也不过是一直在expert徘徊。

反观同级甚至初中的大佬,已经不是Grandmaster就是Master最差Candiate Master了。

考试时候依然起伏不定,思维发挥也没有达到所期望的那种地步。

即便是往年今日,zx2003也早就上紫了啊!

“How BAD do you want it?”

Codeforces Round #513 (rated, Div. 1 + Div. 2)的更多相关文章

  1. Educational Codeforces Round 60 (Rated for Div. 2) - C. Magic Ship

    Problem   Educational Codeforces Round 60 (Rated for Div. 2) - C. Magic Ship Time Limit: 2000 mSec P ...

  2. Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems(动态规划+矩阵快速幂)

    Problem   Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems Time Limit: 3000 mSec P ...

  3. Educational Codeforces Round 43 (Rated for Div. 2)

    Educational Codeforces Round 43 (Rated for Div. 2) https://codeforces.com/contest/976 A #include< ...

  4. Educational Codeforces Round 35 (Rated for Div. 2)

    Educational Codeforces Round 35 (Rated for Div. 2) https://codeforces.com/contest/911 A 模拟 #include& ...

  5. Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings

    Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings 题目连接: http://cod ...

  6. Codeforces Educational Codeforces Round 44 (Rated for Div. 2) E. Pencils and Boxes

    Codeforces Educational Codeforces Round 44 (Rated for Div. 2) E. Pencils and Boxes 题目连接: http://code ...

  7. Educational Codeforces Round 63 (Rated for Div. 2) 题解

    Educational Codeforces Round 63 (Rated for Div. 2)题解 题目链接 A. Reverse a Substring 给出一个字符串,现在可以对这个字符串进 ...

  8. Educational Codeforces Round 39 (Rated for Div. 2) G

    Educational Codeforces Round 39 (Rated for Div. 2) G 题意: 给一个序列\(a_i(1 <= a_i <= 10^{9}),2 < ...

  9. Educational Codeforces Round 48 (Rated for Div. 2) CD题解

    Educational Codeforces Round 48 (Rated for Div. 2) C. Vasya And The Mushrooms 题目链接:https://codeforce ...

随机推荐

  1. java基础第十二篇之集合、增强for循环、迭代器和泛型

    Collection接口中的常用方法: * 所有的子类子接口都是具有的 * 集合的方法:增删改查 * * public boolean add(E e);//添加元素 返回值表示是否添加成功 * pu ...

  2. 洛谷P4568 飞行路线

    题目描述 \(Alice\)和\(Bob\)现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在\(n\)个城市设有业务,设这些城市分别标记为\(0\)到\(n−1\),一共有\(m\ ...

  3. 微信小程序请求openid错误码40163

    通过wx.login({})方法获取到的code只能使用一次,如果需要在哎服务器端再次请求获取openid来进行校验,需要再次通过wx.login({})方法获取code 否则会报错误代码40163, ...

  4. Charles使用小结

    charles,抓包神器,记录几个测试过程中常用的功能 连接同一局域网的开发机     域名跳转MapRemoteSetting     抓取Https接口 1.下载3.10以上破解版,按如下步骤安装 ...

  5. mongodb 分片技术

    MongoDB Sharding Cluster 分片集群 规划:10个实例:38017-38026 (1)configserver:3台构成的复制集(1主两从,不支持arbiter)38018-38 ...

  6. Function.prototype.apply.call

    我们先从一道简单的题目开始,前几天在git上看到的: 定义log方法,它可以代理console.log的方法.log(1,2,3)  =>  1 2 3 通常,你的答案会是这样的: functi ...

  7. 在linux上怎么查看tomcat日志

    进入到tomcat的logs文件夹 tail -f catalina.out

  8. Chrome Java插件过期

    企业应用软件中,基本都是基于某个版本的JDK进行开发的,更新跟不上Oracle更新的步伐,Chrome浏览器自动默认关闭了过期插件导致用Chrome无法打开应用软件. 解决办法如下:

  9. GitHub 开启 Two-factor authentication,如何在命令行下更新和上传代码

    最近在使用GitHub管理代码,在git命令行管理代码时候遇到一些问题. 如果开起了二次验证(Two-factor authentication两个要素认证),命令行会一直提示输入用户名和密码.查找了 ...

  10. 微软Coco Blockchain Framework:一键解决企业级区块链三大难题

    近年来,异军突起的“区块链”受到全行业的广泛关注,众多企业级用户在积极拥抱新技术的过程中却面临三大难题:性能.隐私和组织管理.如果不能很好地解决这些“顽固分子”,区块链技术就相对局限,很难发挥出应有的 ...