Codeforces 381 简要题解
做的太糟糕了。。。第一题看成两人都取最优策略,写了个n^2的dp,还好pre-test良心(感觉TC和CF的pretest还是很靠谱的),让我反复过不去,仔细看题原来是取两边最大的啊!!!前30分钟就这样度过了。。。题目的分数啊刷刷掉啊( ˙灬˙ )。用了8分钟搞完第二题,然后第三题。第五题在1:20左右的时候开始写一个树状数组,1:29的时候写完了,结果样例不过,仔细看看居然是树状数组修改时从1开始修改的,无语啊。于是就。。。。。。只做上了3道题,被虐的好惨啊。。。
第一题:模拟。。
第二题:水题
第三题:暴力到100000(l[i]的最大值)
- /*
- * Problem: C. Sereja and Prefixes
- * Author: Shun Yao
- */
- #include <string.h>
- #include <stdlib.h>
- #include <limits.h>
- #include <assert.h>
- #include <stdio.h>
- #include <ctype.h>
- #include <math.h>
- #include <time.h>
- #include <map>
- #include <set>
- #include <list>
- #include <stack>
- #include <queue>
- #include <deque>
- #include <string>
- #include <vector>
- #include <bitset>
- #include <utility>
- #include <iomanip>
- #include <numeric>
- #include <sstream>
- #include <iostream>
- #include <algorithm>
- #include <functional>
- //using namespace std;
- int m, n, a[100010], b[100010], c[100010], e[100010];
- long long d[100010];
- int main(/*int argc, char **argv*/) {
- int i, j, k;
- long long len;
- scanf("%d", &m);
- for (i = 1; i <= m; ++i) {
- scanf("%d", &a[i]);
- if (a[i] == 1)
- scanf("%d", &b[i]);
- else
- scanf("%d %d", &b[i], &c[i]);
- }
- scanf("%d", &n);
- for (i = 1; i <= n; ++i)
- scanf("%I64d", &d[i]);
- j = 1;
- len = 0;
- for (i = 1; i <= m; ++i) {
- if (a[i] == 1) {
- ++len;
- if (len <= 100000)
- e[len] = b[i];
- while (j <= n && d[j] == len) {
- ++j;
- printf("%d ", b[i]);
- }
- } else {
- if (len < 100000) {
- for (k = len + 1; k <= 100000 && k <= len + b[i] * c[i]; ++k)
- e[k] = e[(k - len) % b[i] == 0 ? b[i] : (k - len) % b[i]];
- }
- while (j <= n && d[j] <= len + b[i] * c[i]) {
- printf("%d ", e[(d[j] - len) % b[i] == 0 ? b[i] : (d[j] - len) % b[i]]);
- ++j;
- }
- len += b[i] * c[i];
- }
- }
- fclose(stdin);
- fclose(stdout);
- return 0;
- }
第四题:分层记录线段(即l,r,x),依次查询每层,记录出现过的颜色。(不用__builtin_clz会tle的。。)
- /*
- * Problem: Sereja and Tree
- * Author: Shun Yao
- */
- #include <string.h>
- #include <stdlib.h>
- #include <limits.h>
- #include <assert.h>
- #include <stdio.h>
- #include <ctype.h>
- #include <math.h>
- #include <time.h>
- #include <map>
- #include <set>
- #include <list>
- #include <stack>
- #include <queue>
- #include <deque>
- #include <string>
- #include <vector>
- #include <bitset>
- #include <utility>
- #include <iomanip>
- #include <numeric>
- #include <sstream>
- #include <iostream>
- #include <algorithm>
- #include <functional>
- //using namespace std;
- int n, m, z[7010];
- int u;
- std::map<int, int> rn;
- class Data {
- public:
- int first, second, third;
- Data() {}
- Data(int f, int s, int t) : first(f), second(s), third(t) {}
- } ;
- std::vector<Data> g[7010];
- int main(/*int argc, char **argv*/) {
- int i, t, l, r, x;
- // freopen("D.in", "r", stdin);
- // freopen("D.out", "w", stdout);
- scanf("%d%d", &n, &m);
- u = 0;
- for (i = 1; i <= m; ++i) {
- scanf("%d", &t);
- if (t == 1) {
- scanf("%d%d%d%d", &t, &l, &r, &x);
- g[t].push_back(Data(l, r, rn.count(x) ? rn[x] : rn[x] = u++));
- } else {
- scanf("%d%d", &t, &l);
- for (r = l; t <= n; ++t) {
- for (x = 0; x < static_cast<int>(g[t].size()); ++x)
- if (std::max(g[t][x].first, l) <= std::min(g[t][x].second, r))
- z[g[t][x].third] = i;
- if (l > 1)
- l += 32 - __builtin_clz(l - 1);
- r += 32 - __builtin_clz(r);
- }
- x = 0;
- for (t = 0; t < u; ++t)
- x += z[t] == i;
- printf("%d\n", x);
- }
- }
- fclose(stdin);
- fclose(stdout);
- return 0;
- }
第五题:
官方题解给的是线段树。
我用树状数组离线搞的。
Codeforces 381 简要题解的更多相关文章
- Codeforces 863 简要题解
文章目录 A题 B题 C题 D题 E题 F题 G题 传送门 简要题解?因为最后一题太毒不想写了所以其实是部分题解... A题 传送门 题意简述:给你一个数,问你能不能通过加前导000使其成为一个回文数 ...
- Codeforces 1120 简要题解
文章目录 A题 B题 C题 D题 E题 F题 传送门 A题 传送门 题意简述:给你一个mmm个数的数列,现在规定把一个数列的1,2,...,k1,2,...,k1,2,...,k分成第一组,把k+1, ...
- Codeforces 1098 简要题解
文章目录 前言 A题 B题 C题 D题 E题 传送门 前言 没错因为蒟蒻太菜了这场的最后一道题也咕掉了,只有AAA至EEE的题解233 A题 传送门 题意简述:给出一棵带点权的树,根节点深度为111, ...
- Codeforces 1110 简要题解
文章目录 A题 B题 C题 D题 E题 F题 G题 传送门 众所周知ldxoildxoildxoi这种菜鸡选手是不会写HHH题的,因此该篇博客只有AAA题至GGG题的题解,实在抱歉. A题 传送门 题 ...
- Codeforces 380 简要题解
ABC见上一篇. 感觉这场比赛很有数学气息. D: 显然必须要贴着之前的人坐下. 首先考虑没有限制的方案数.就是2n - 1(我们把1固定,其他的都只有两种方案,放完后长度为n) 我们发现对于一个限制 ...
- Codeforces 845 简要题解
文章目录 A题 B题 C题 D题 E题 F题 G题 传送门 A题 传送门 题意:2n2n2n个人下棋,分为两个阵营,每个阵营nnn个人,每个人有一个积分,积分高的能赢积分低的,问如果你可以随意选人,然 ...
- Codeforces 1065 简要题解
文章目录 A题 B题 C题 D题 E题 F题 G题 传送门 GGG题略难,膜了一波zhouyuyang{\color{red} zhouyuyang}zhouyuyang巨佬的代码. 其余都挺清真的. ...
- Codeforces 888 简要题解
文章目录 A题 B题 C题 D题 E题 F题 G题 传送门 A题 传送门 题意简述:给一个数列,问有多少个峰值点(同时比两边都大/小的点) 思路:按照题意模拟. 代码: #include<bit ...
- Codeforces 884 简要题解
文章目录 A题 B题 C题 D题 E题 F题 传送门 A题 传送门 题意简述: 一个人要完成一件事总共需要ttt秒,现在有nnn天,每天有aia_iai不能做事,问他可以在第几天做完. 思路:按照题 ...
随机推荐
- Python数字加千分符
1.最简单的内置format函数: >>> format(1234567890,',') '1,234,567,890' 2.正则表达式: import re def formatN ...
- JS代码片段:判断一个元素是否进入可视区域
// Determine if an element is in the visible viewport function isInViewport(element) { var rect = el ...
- ios开发之 MPMoviePlayerController 视频播放器
MPMoviePlayerController 与AVAudioPlayer有点类似,前者播放视频,后者播放音频,不过也有很大不同,MPMoviePlayerController 可以直接通过远程UR ...
- Linux命令之chmod 及+s 参数(临时以所有者权限执行)
转自: http://blog.csdn.net/shaobingj126/article/details/7031221 chmod用于改变文件或目录的访问权限.用户用它控制文件或目录的访问权限.该 ...
- npm在项目目录安装插件需要使用sudo
今天使用node的npm安装插件的时候遇到一个问题,那就是在项目目录里面安装插件的时候,必须使用超级用户(sudo)执行才会安装成功,否则会报如下错误: 以安装 gulp-uglify 为例 $ np ...
- perl基本语法
标量 标量是 Perl 中最简单的数据类型.大多数的标量是数字(如 255 或 3.25e20)或者字符串(如 hello或者盖茨堡地址). 数字 perl中所有数字内部的格式都是双精度浮点数. 浮点 ...
- sdut 2831 Euclid (几何)
题目:http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2831 题意:给a, b, c, d, ...
- 函数fil_io
/********************************************************************//** Reads or writes data. This ...
- bzoj2436
不难发现两边的活动是交替进行的,我们可以dp 先对时间离散化,设f[i,j]到时间i一个会场选j个活动,另一个会场最多有多少活动,那么f[i,j]=max(f[k,j]+s[k,i],f[k,j-s[ ...
- Asp.Net Unix时间戳和DateTime类型转换
using System; using System.Collections.Generic; using System.Web; using System.Web.UI; using System. ...