模拟赛20181031 雅礼 Wearry 养花 折射 画作
% Day1 Solution
% Wearry
% Stay determined!
养花
考虑当 kkk 确定的时候如何求答案,
显然对于所有形如 [ak,(a+1)k)[ak, (a+1)k)[ak,(a+1)k) 的值域区间, 最大值一定是最优的.
进一步观察发现, 这样的区间总个数只有 klnkk \ln kklnk 个.
考虑分块, 那么我们可以在 O(n+klnk)O(n + k \ln k)O(n+klnk) 的时间复杂度内处理出一个块对于任意 kkk 的答案.
询问时复杂度是 O(mS)O(mS)O(mS) 的, 取 S=klnkS = \sqrt{k \ln k}S=klnk 可以达到最优复杂度 O(nklnk)O(n \sqrt{k \ln k})O(nklnk).
#include <bits/stdc++.h>
using namespace std;
const int MAXN = 100000;
const int B = 1000;
int n, m, A[MAXN+5], ans[MAXN/B+5][MAXN+5], b[MAXN+5];
int main ()
{
scanf("%d%d", &n, &m);
for(int i = 0; i < n; i++)
scanf("%d", &A[i]);
int blks = (n-1)/B+1;
for(int i = 0; i < blks; i++)
{
memset(b, 0, sizeof b);
for(int j = i*B; j < B*(i+1) && j < n; j++) b[A[j]] = A[j];
for(int j = 1; j <= MAXN; j++) if(!b[j]) b[j] = b[j-1];
for(int j = 1; j <= MAXN; j++) for(int k = 0; k <= MAXN; k += j) ans[i][j] = max(ans[i][j], b[min(k+j-1,MAXN)]-k);
}
int x, y, z, a, b, Ans;
while(m--)
{
scanf("%d%d%d", &x, &y, &z), x--, y--;
a = x/B + 1, b = y/B, Ans = 0;
if(a > b) for(int i = x; i <= y; i++) Ans = max(Ans, A[i]%z);
else
{
for(int i = x; i < a*B; i++) Ans = max(Ans, A[i]%z);
for(int i = b*B; i <= y; i++) Ans = max(Ans, A[i]%z);
for(int i = a; i < b; i++) Ans = max(Ans, ans[i][z]);
}
printf("%d\n", Ans);
}
}
折射
若将所有点按照 yiy_iyi 的顺序转移, 有上界和下界两个限制, 难以优化.
考虑按照 xix_ixi 排序转移, 并记录 fi,0/1f_{i, 0/1}fi,0/1 表示以第 iii 个点为顶端接下来向左或向右的折线方案数.
从左到右加点, 考虑前 iii 个点构成的包含 iii 点的折线. 由于新点横坐标最大, 所以只可能在折线的第一位或第二位:
∀yj<yi,fi,0←fj,1\forall y_j < y_i, f_{i, 0} \leftarrow f_{j, 1}∀yj<yi,fi,0←fj,1
∀yj>yi,fj,1←fk,0∣xk>xj  and  yk<yi\forall y_j > y_i, f_{j, 1} \leftarrow f_{k, 0} \mid x_k > x_j \,\, \mathrm{and} \,\, y_k < y_i∀yj>yi,fj,1←fk,0∣xk>xjandyk<yi
第二种情况可以前缀和优化, 复杂度 O(n2)O(n^2)O(n2).
#include <bits/stdc++.h>
using namespace std;
#define file(x) freopen(x".in", "r", stdin);freopen(x".out", "w", stdout);
#define pii pair<int,int>
namespace IO
{
inline void read(int &num)
{
char ch; int flag = 1;
while(!isdigit(ch=getchar()))if(ch=='-')flag=-flag;
for(num=ch-'0';isdigit(ch=getchar());num=num*10+ch-'0');
num *= flag;
}
}
using namespace IO;
const int MAXN = 100005;
const int mod = 1e9+7;
int n, dp[MAXN][2];
pii p[MAXN];
int main ()
{
read(n);
for(int i = 1; i <= n; i++)
read(p[i].first), read(p[i].second);
sort(p + 1, p + n + 1);
int Ans = 0;
for(int i = 1; i <= n; i++)
{
dp[i][0] = dp[i][1] = 1;
for(int j = i-1; j; j--)
if(p[j].second < p[i].second)
(dp[i][0] += dp[j][1]) %= mod;
else (dp[j][1] += dp[i][0]) %= mod;
}
for(int i = 1; i <= n; i++) (Ans += (dp[i][0] + dp[i][1]) % mod) %= mod;
printf("%d\n", (Ans+mod-n)%mod);
}
画作
不难证明猜到一个这样的结论: 存在一种最优方案使得每次操作的区域是上一次的子集且颜色与上一次相反.
考虑归纳证明, 记 SSS 为当前所有操作区域的并, TTT 为接下来一步的操作区域, 我们有:
TTT 与 SSS 有交的情况一定可以转化成 TTT 被 SSS 包含的情况.
TTT 与 SSS 交集为空时, 可以找一个连接 SSS 和 TTT 的集合 MMM 并操作 S∪T∪MS \cup T \cup MS∪T∪M,
并将之前的所有操作连接到更外的层以及外层的连接部分同时操作, 特殊处理最外层和第二层的情况.TTT 被 SSS 包含时, TTT 落在某个完整区域内时等价于情况二,
否则一定连接若干个同色块, 这些块可以同时处理, 步数一定不会更劣.
知道这个结论就比较好做了, 我们可以枚举最后被修改的区域,
这时答案就是将同色边边权当作 000, 异色边边权当作 111 后距离这个点最远的黑色点的距离, 对所有点取最小值即可.
#include <bits/stdc++.h>
using namespace std;
const int MAXN = 55, MAXM = 55;
#define pii pair<int,int>
#define mp make_pair
#define X first
#define Y second
int dx[4] = { 0, 0, 1, -1 };
int dy[4] = { 1, -1, 0, 0 };
char s[MAXN][MAXM];
int dis[MAXN][MAXM], n, m;
deque<pii>q;
inline bool chkmin(int &A, int B) { return B < A ? A = B, 1 : 0; }
inline bool chkmax(int &A, int B) { return B > A ? A = B, 1 : 0; }
int bfs(int u, int v)
{
memset(dis, -1, sizeof dis);
int ret = -1;
dis[u][v] = 0; q.push_back(mp(u, v));
while(!q.empty())
{
pii tp = q.front(); q.pop_front();
if(s[tp.X][tp.Y] == '1') chkmax(ret, dis[tp.X][tp.Y]);
for(int i = 0; i < 4; i++)
if((u=tp.X+dx[i]) >= 1 && (v=tp.Y+dy[i]) >= 1 && u <= n && v <= m && dis[u][v] == -1)
{
if(s[tp.X][tp.Y] == s[u][v])
dis[u][v] = dis[tp.X][tp.Y], q.push_front(mp(u, v));
else dis[u][v] = dis[tp.X][tp.Y] + 1, q.push_back(mp(u, v));
}
}
return ret;
}
int main()
{
scanf("%d%d", &n, &m);
for(int i = 1; i <= n; i++)
scanf("%s", s[i]+1);
int Ans = 0x7f7f7f7f;
for(int i = 1; i <= n; i++)
for(int j = 1; j <= m; j++)
chkmin(Ans, bfs(i, j));
printf("%d\n", Ans+1);
}
模拟赛20181031 雅礼 Wearry 养花 折射 画作的更多相关文章
- 模拟赛20181101 雅礼 Wearry 施工 蔬菜 联盟
% Day2 Solution % Wearry % Stay determined! 施工 记 fif_{i}fi 表示考虑前 iii 个建筑, 并且第 iii 个建筑的高度不变的答案, 每 ...
- 雅礼集训 Day1 T3 画作 解题报告
画作 题目描述 小\(\mathrm{G}\)的喜欢作画,尤其喜欢仅使用黑白两色作画. 画作可以抽象成一个\(r\times c\)大小的\(01\)矩阵.现在小\(\mathrm{G}\)构思好了他 ...
- NOIP2018 模拟赛(二十二)雅礼NOI
Preface 这次的题目都是NOI+的题,所以大家的分数都有点惨烈. 依靠T1大力骗分水到Rank2 所以想看正解的话看这里吧 A. 「雅礼NOI2018模拟赛(一) Day1」树 看一眼题目感觉十 ...
- 雅礼集训 Day1 T1 养花
养花 题目描述 小\(C\)在家种了\(n\)盆花,每盆花有一个艳丽度\(a_i\). 在接下来的\(m\)天中,每天早晨他会从一段编号连续的花中选择一盆摆放在客厅, 并在晚上放回. 同时每天有特定的 ...
- 雅礼集训1-9day爆零记
雅礼集训1-9day爆零记 先膜一下虐爆我的JEFF巨佬 Day0 我也不知道我要去干嘛,就不想搞文化科 (文化太辣鸡了.jpg) 听李总说可以去看(羡慕)各路大佬谈笑风声,我就报一个名吧,没想到还真 ...
- [NOIP2018模拟赛10.22]咕咕报告
闲扯 这是篇咕咕了的博客 考场上码完暴力后不知道干什么,然后忽然发现这个T1好像有点像一道雅礼集训时讲过的CF题目 Rest In Shades ,当时那道题还想了挺久不过思路比较妙,于是我就也\(y ...
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- NOI模拟赛 Day1
[考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...
- NOIP第7场模拟赛题解
NOIP模拟赛第7场题解: 题解见:http://www.cqoi.net:2012/JudgeOnline/problemset.php?page=13 题号为2221-2224. 1.car 边界 ...
随机推荐
- 1.JVM前奏篇(看官网怎么说)
JVM(Java Virtual Machine) 前奏篇(看官网规范怎么说) 1.The relation of JDK/JRE/JVM 在下图中,我们所接触的,最熟悉,也是经常打交道的 最顶层 J ...
- day42——外键的限制和解决方法、外键的三种约束模式、修改表(单表查询)
day42 外键的限制和解决方法 可以添加外键关联的那个字段可以是 被唯一(unique)约束的字段 或者 主键 限制:+ 由于外键的使用,致使多个表之间产生了联系,当我们对这些表进行更新或删除操作的 ...
- 10分钟用scratch写一个大鱼吃小鱼的小游戏
第一次给张江小朋友教Scratch课程之前,还在担心一些概念能不能向小朋友解释清楚,可上完课发现,我严重低估了小朋友的聪明程度,发现现在的孩子相比较自己8.9岁的时候,简直聪明太多倍了. 所以总结了半 ...
- Spring Cloud--服务的发布与调用示例
[Provider] 引依赖: 启动类上添加注解: 配置文件: [Consumer] 引依赖: 加注解: 配置文件: 调用服务: 方式一(动态获取服务列表): Eureka默认30秒拉取一次服务列表. ...
- [LOJ2065] [SDOI2016]模式字符串
题目链接 洛谷:https://www.luogu.org/problemnew/show/P4075 LOJ:https://loj.ac/problem/2065 Solution 这种题看起来就 ...
- 全栈项目|小书架|服务器开发-NodeJS 中使用 Sequelize 操作 MySQL数据库
安装 官网:https://sequelize.org/v5/manual/getting-started.html 安装sequelize及数据库连接驱动 npm install --save se ...
- Java的集合整理
1.List和Set都是接口,他们都继承于接口Collection,List是一个有序的可重复的集合,而Set的无序的不可重复的集合.Collection是集合的顶层接口,Collections是一个 ...
- Abp session和Cookie
问道 面向Abp 在面向服务的时候,Session 干嘛用? 先把Session 的作用说了,但是在微服务环境下给忽略了,相当于忽略了核心. Session 只是个功能.就是根据Cookie 的Ses ...
- ADO.NET 三(Command)
操作数据库需则要用到 Command 类中提供的属性和方法.下面来介绍一下如何使用 Command 类来操作数据表中的数据. Command 类概述 在 System.Data.SqlClient 命 ...
- 分享个免费的svn平台
平时在工作中难免会用到svn,但是要自己搭建一个,未免成本太高,近来,本人接触到一个免费的svn平台(可能大神们早就发现了),个人使用还是足够了. 地址:https://svnbucket.com 相 ...