题解

断环为链,把链复制两份

用set维护一下全是0的区间,然后查找x + n / 2附近的区间,附近各一个过不去,最后弃疗了改为查附近的两个,然后过掉了= =

熟练掌握stl的应用,你值得拥有(雾

代码

#include <bits/stdc++.h>
//#define ivorysi
#define enter putchar('\n')
#define space putchar(' ')
#define fi first
#define se second
#define pb push_back
#define mp make_pair
#define eps 1e-8
#define mo 974711
#define MAXN 200005
#define pii pair<int,int>
using namespace std;
typedef long long int64;
typedef double db;
template<class T>
void read(T &res) {
res = 0;char c = getchar();T f = 1;
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 + c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {putchar('-');x = -x;}
if(x >= 10) {
out(x / 10);
}
putchar('0' + x % 10);
}
int N,M;
int A[MAXN * 2],B[MAXN * 2];
char ch[MAXN * 2][3];
set<pii > S;
void Change(int p,int v) {
if(B[p] == v) return;
if(B[p] != 0 && v != 0) {B[p] = v;return;}
if(B[p] == 0) {
auto k = S.upper_bound(mp(p,4 * N));
--k;
pii t = *k;
S.erase(k);
if(p - 1 >= t.fi) S.insert(mp(t.fi,p - 1));
if(p + 1 <= t.se) S.insert(mp(p + 1,t.se));
}
else {
auto k = S.upper_bound(mp(p,4 * N)),g = k;
--g;
pii t2 = *k,t1 = *g;
if(t1.se == p - 1 && t2.fi == p + 1) {
S.erase(k);S.erase(g);
S.insert(mp(t1.fi,t2.se));
}
else if(t1.se == p - 1) {
S.erase(g);S.insert(mp(t1.fi,p));
}
else if(t2.fi == p + 1) {
S.erase(k);S.insert(mp(p,t2.se));
}
else {
S.insert(mp(p,p));
}
}
B[p] = v;
}
int check(int p,pii t) {
if(t.fi == 4 * N || t.fi == -4 * N) return 0;
if((t.fi <= p && t.se >= p) || (t.fi <= p + N && t.se >= p + N)) return 0;
else return min(t.fi - p,p + N - t.se);
}
int Query(int p) {
if(S.size() == 2) return -1;
auto k = S.lower_bound(mp(p + N / 2,4 * N)),g = k,h = k;
--g;++h;
int res = 0;
pii t = *k;
res = max(check(p,t),res);
t = *g;
res = max(check(p,t),res);
if(h != S.end()) t = *h,res = max(check(p,t),res),++h;
if(g != S.begin()) {
--g;t = *g;res = max(check(p,t),res);
}
if(h != S.end()) {
t = *h;res = max(check(p,t),res);
}
return res;
}
int calc(int a,int b,char op) {
if(op == '*') return a * b % 10;
else return (a + b) % 10;
}
void Solve() {
read(N);read(M);
S.insert(mp(4 * N,4 * N));
S.insert(mp(-4 * N,-4 * N));
for(int i = 1 ; i <= N ; ++i) {
read(A[i]);scanf("%s",ch[i] + 1);
}
A[0] = A[N];
for(int i = 1 ; i <= N ; ++i) {
B[i] = calc(A[i],A[i - 1],ch[i][1]);
}
for(int i = 1 ; i <= N ; ++i) B[i + N] = B[i],A[i + N] = A[i];
int p = -1;
for(int i = 1 ; i <= 2 * N ; ++i) {
if(B[i] == 0) {
if(p == -1) p = i;
}
else if(p != -1) {
S.insert(mp(p,i - 1));
p = -1;
}
}
if(p != -1) S.insert(mp(p,2 * N));
int op,num;char s[5];
for(int i = 1 ; i <= M ; ++i) {
read(op);
if(op == 1) {
read(p);read(num);scanf("%s",s + 1);
++p;
if(p == N) {
Change(1,calc(A[1],num,ch[1][1]));
Change(N + 1,calc(A[1],num,ch[1][1]));
}
else {
Change(p + 1,calc(A[p + 1],num,ch[p + 1][1]));
Change(p + 1 + N,calc(A[p + 1],num,ch[p + 1][1]));
}
A[p] = A[p + N] = num;ch[p][1] = s[1];
Change(p,calc(A[p],A[p - 1],s[1]));
Change(p + N,calc(A[p],A[p - 1],s[1]));
if(p == N) A[0] = num;
}
else {
read(p);++p;
int t = B[p];
Change(p,A[p]);
out(Query(p));enter;
Change(p,t);
}
}
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Solve();
return 0;
}

【LOJ】#2010. 「SCOI2015」小凸解密码的更多相关文章

  1. 「SCOI2015」小凸解密码 解题报告

    「SCOI2015」小凸解密码 题意:给一个环,定义一段连续的极长\(0\)串为\(0\)区间,定义一个位置的离一个\(0\)区间的距离为这个位置离这个区间中\(0\)的距离的最小值,每次询问一个位置 ...

  2. loj#2009.「SCOI2015」小凸玩密室

    题目链接 loj#2009. 「SCOI2015」小凸玩密室 题解 树高不会很高<=20 点亮灯泡x,点亮x的一个子树,再点亮x另外的子树, 然后回到x的父节点,点亮父节点之后再点亮父节点的其他 ...

  3. loj #2008. 「SCOI2015」小凸想跑步

    #2008. 「SCOI2015」小凸想跑步   题目描述 小凸晚上喜欢到操场跑步,今天他跑完两圈之后,他玩起了这样一个游戏. 操场是个凸 n nn 边形,N NN 个顶点按照逆时针从 0∼n−1 0 ...

  4. loj #2006. 「SCOI2015」小凸玩矩阵

    #2006. 「SCOI2015」小凸玩矩阵   题目描述 小凸和小方是好朋友,小方给小凸一个 N×M N \times MN×M(N≤M N \leq MN≤M)的矩阵 A AA,要求小凸从其中选出 ...

  5. LibreOJ #2006. 「SCOI2015」小凸玩矩阵 二分答案+二分匹配

    #2006. 「SCOI2015」小凸玩矩阵 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据   题目描述 ...

  6. 「SCOI2015」小凸想跑步 解题报告

    「SCOI2015」小凸想跑步 最开始以为和多边形的重心有关,后来发现多边形的重心没啥好玩的性质 实际上你把面积小于的不等式列出来,发现是一次的,那么就可以半平面交了 Code: #include & ...

  7. 「SCOI2015」小凸玩矩阵 解题报告

    「SCOI2015」小凸玩矩阵 我好沙茶啊 把点当边连接行和列,在外面二分答案跑图的匹配就行了 我最开始二分方向搞反了,样例没过. 脑袋一抽,这绝壁要费用流,连忙打了个KM 然后wa了,一想这个不是完 ...

  8. 「SCOI2015」小凸玩密室 解题报告

    「SCOI2015」小凸玩密室 虽然有心里在想一些奇奇怪怪的事情的原因,不过还是写太久了.. 不过这个题本身也挺厉害的 注意第一个被点亮的是任意选的,我最开始压根没注意到 \(dp_{i,j}\)代表 ...

  9. AC日记——「SCOI2015」小凸玩矩阵 LiBreOJ 2006

    「SCOI2015」小凸玩矩阵 思路: 二分+最大流: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 300 ...

随机推荐

  1. vs下给生成的程序(exe)加入默认的申请管理员权限

    在vs下编程时,经常会用到一些特殊的权限,尤其是管理员权限,下面是在win7下笔者亲测通过的. 下面要分两种情况: 第一种情况就是在vs2003或者以下的编译器中运行 1.准备一个manifest文件 ...

  2. [python]乱码:python抓取脚本

    参考: http://www.zhxl.me/1409.html 使用 python urllib2 抓取网页时出现乱码的解决方案 发表回复 这里记录的是一个门外汉解决使用 urllib2 抓取网页时 ...

  3. scrapy 采集网页出现丢失url的问题

    url_list = ["http://www.icoat.cc/news/list_18_3.html", "http://www.icoat.cc/news/list ...

  4. 巧用Java中Calendar工具类

    Java的JDK中提供了一系列好用的util工具类.Calendar就是java.util中用于处理日期的工具类.且该工具类易学易用实用. 工具类Calendar是抽象类. PS:为什么把Calend ...

  5. Linux centos7下设置Tomcat开机自启动

    1,centos7 使用 systemctl 替换了 service命令 参考:redhat文档: https://access.redhat.com/documentation/en-US/Red_ ...

  6. 维护前面的position+主席树 Codeforces Round #406 (Div. 2) E

    http://codeforces.com/contest/787/problem/E 题目大意:给你n块,每个块都有一个颜色,定义一个k,表示在区间[l,r]中最多有k中不同的颜色.另k=1,2,3 ...

  7. NYOJ 93 汉诺塔 (数学)

    题目链接 描述 在印度,有这么一个古老的传说:在世界中心贝拿勒斯(在印度北部)的圣庙里,一块黄铜板上插着三根宝石针.印度教的主神梵天在创造世界的时候,在其中一根针上从下到上地穿好了由大到小的64片金片 ...

  8. 大聊PYthon----生成器

    再说迭代器与生成器之前,先说一说列表生成式 列表生成式 什么是列表生成式呢? 这个非常简单! 先看看普通青年版的! >>> a [0, 1, 2, 3, 4, 5, 6, 7, 8, ...

  9. 大聊Python----装饰器

    什么是装饰器? 装饰器其实和函数没啥区别,都是用def去定义的,其本质就是函数,而功能就是装饰其他的函数,说白了就是为其他函数提供附加功能 装饰器有什么作用? 比如你是一个公司的员工,你所写的程序里有 ...

  10. 【译】第一篇 SQL Server代理概述

    本篇文章是SQL Server代理系列的第一篇,详细内容请参考原文. SQL Server代理是SQL Server的作业调度和告警服务,如果使用得当,它可以大大简化DBA的工作量.SQL Serve ...