题目描述

  小$G$有一个长度为$n$的$01$串$T$,其中只有$T_S=1$,其余位置都是$0$。现在小$G$可以进行若干次以下操作:
  $\bullet$选择一个长度为K的连续子串($K$是给定的常数),翻转这个子串。
  对于每个$i,i\in[1,n]$,小$G$想知道最少要进行多少次操作使得$T_i=1$。特别的,有$m$个“禁止位置”,你需要保证在操作过程中$1$始终不在任何一个禁止位置上。


输入格式

  从文件$reverse.in$中读入数据。
  第一行四个整数$n,K,m,S$。
  接下来一行$m$个整数表示禁止位置。


输出格式

  输出到文件$reverse.out$中。
  输出一行$n$个整数,对于第$i$个整数,如果可以通过若干次操作使得$T_i=1$,输出最小操作次数,否则输出$−1$。


样例

样例输入1:

6 2 0 1

样例输出1:

0 1 2 3 4 5

样例输入2:

10 4 3 3
2 5 10

样例输出2:

2 -1 0 1 -1 1 2 3 2 -1


数据范围与提示

对于所有数据,有$1\leqslant n\leqslant 10^5,1\leqslant S,k\leqslant n,0\leqslant m\leqslant n$。
保证$S$不是禁止位置,但禁止位置可能有重复。
$\bullet Subtask1(24\%)$,$n\leqslant 10$。
$\bullet Subtask2(22\%)$,$n\leqslant 10^3$。
$\bullet Subtask3(3\%)$,$k=1$。
$\bullet Subtask4(8\%)$,$k=2$。
$\bullet Subtask5(43\%)$,没有特殊的约束。


题解

首先解释一下题意,翻转子串指的是将其左右颠倒,而不是异或……

我也不知道为什么会理解错,老是死在语文……

就是一道大模拟,正解用$set$维护,但是可以疯狂加剪枝,但是理论时间复杂度还是线性的,具体剪枝看代码吧,满眼都是泪哇……

不过话说考试的时候看样例找规律能水到$11$分我也是满足了……

时间复杂度:$\Theta(n)$。

期望得分:$100$分。

实际得分:$100$分。


代码时刻

#include<bits/stdc++.h>
using namespace std;
int n,K,m,S;
bool vis[100001];
int L[100001],R[100001];
int dis[100001];
queue<int> q;
void BFS()
{
q.push(S);
vis[S]=1;
while(!q.empty())
{
int x=q.front();q.pop();
for(int i=max(1,x-K);i<=min(x,n-K);i++)
{
int t=K-x+(i<<1);
if(t>x)break;
if(!vis[t]&&dis[t]!=-1)
{
vis[t]=1;
dis[t]=dis[x]+1;
q.push(t);
}
if(dis[t]!=-1)i=max(i,(x+R[t]-K)>>1);
L[t]=min(L[t],K-x+max(1,x-K)*2);
R[t]=max(R[t],K-x+min(x,n-K)*2);
}
for(int i=min(x,n-K);i>=max(1,x-K);i--)
{
int t=K-x+(i<<1);
if(t<=x)break;
if(!vis[t]&&dis[t]!=-1)
{
vis[t]=1;
dis[t]=dis[x]+1;
q.push(t);
}
if(dis[t]!=-1)i=min(i,(x+L[t]-K)>>1);
L[t]=min(L[t],K-x+max(1,x-K)*2);
R[t]=max(R[t],K-x+min(x,n-K)*2);
}
}
}
int main()
{
scanf("%d%d%d%d",&n,&K,&m,&S);K--;
memset(dis,0x3f,sizeof(dis));dis[S]=0;
for(int i=1;i<=n;i++)L[i]=R[i]=i;
while(m--)
{
int x;scanf("%d",&x);
dis[x]=-1;
}
BFS();
for(int i=1;i<=n;i++)
{
if(dis[i]==0x3f3f3f3f)printf("-1 ");
else printf("%d ",dis[i]);
}
return 0;
}

rp++

[CSP-S模拟测试]:Reverse(模拟+暴力+剪枝)的更多相关文章

  1. [CSP-S模拟测试]:D(暴力+剪枝)

    题目传送门(内部题47) 输入格式 第一行一个正整数$n$.第二行$n$个正整数,表示序列$A_i$. 输出格式 一行一个正整数,表示答案. 样例 样例输入: 530 60 20 20 20 样例输出 ...

  2. [CSP-S模拟测试]:reverse(模拟)

    题目传送门(内部题56) 输入格式 第一行包含一个整数:$T$,表示数据组数.接下来$T$行,每行包含两个字符串:$a\ b$. 输出格式 对于每组数据,如果存在$c$,输出最长的情况下字典序最大的$ ...

  3. [CSP-S模拟测试]:reverse(数位DP)

    题目描述 我们定义: $\overline{d_k...d_2d_1}=\sum \limits_{i=1}^kd_i\times {10}^{i-1}=n(d_i\in [0,9]\ and\ d_ ...

  4. [CSP-S模拟测试]:公园(BFS+剪枝)

    题目传送门(内部题31) 输入格式 第一行,五个整数$V,M,N,E,L$.接下来$M$行,每行两个正整数$s_i,a_i$.保证$s_i$互不相等.接下来$N$行,每行两个正整数$t_j,b_j$. ...

  5. [CSP-S模拟测试]:传递(暴力+bitset)

    题目描述 我们称一个有向图$G$是传递的,当且仅当对于图$G$的三个不同顶点$a,b,c$,若图$G$中有一条边从$a$到$b$且有一条边从$b$到$c$,那么图中也有一条边从$a$到$c$.我们称一 ...

  6. [CSP-S模拟测试]:寿司(暴力)

    题目描述 小$c$是一名$oier$.最近,他发现他的数据结构好像学傻了.因为他在刷题时碰到了一道傻逼数据结构题,强行使用了平衡树来解决,卡着时间$AC$.为此,他被狠狠地嘲讽了一番.于是,小$c$找 ...

  7. [CSP-S模拟测试]:Median(暴力+模拟)

    题目描述 定义两个数列: $$S=\{S(1),S(2),...,S(n)\}\text{和}S_2\{S_2(1),S_2(2),...,S_2(n)\}$$ $$S(k)=(p_k\times k ...

  8. 模拟测试—moq:简单一两句

    在Xunit的基础上,说话模拟测试. 假如我们有这样一个控制器里面有这样一个方法,如图 我们在对Bar测试得时候,如果测试未通过,错误有可能来至于Bar,也有可能错误来至于serverde Foo方法 ...

  9. NOIP模拟测试19「count·dinner·chess」

    反思: 我考得最炸的一次 怎么说呢?简单的两个题0分,稍难(我还不敢说难,肯定又有人喷我)42分 前10分钟看T1,不会,觉得不可做,完全不可做,把它跳了 最后10分钟看T1,发现一个有点用的性质,仍 ...

随机推荐

  1. Java 与 C++ 的比较

    参考 Java 中,一切皆是类 Java 中,所有数据或方法都要放在类中.如果想获得与全局函数等价的功能,可将static方法和static数据放在类里.而 C++ 中有 struct 结构.enum ...

  2. iis7 https配置方法并且http跳转https

    操作场景 本文档指导您如何在 IIS 中安装 SSL 证书. 说明: 本文档以证书名称 www.domain.com 为例. 本文档以操作系统 Windows10 为例.由于操作系统的版本不同,详细操 ...

  3. c# asp.net uploadify 上传大文件 出现的 HTTP 404 问题

    用uploadify在IIS6下上传大文件没有问题,但是迁移到IIS7下面,上传大文件时,出现HTTP 404错误. 查了半天,原来是IIS7下的默认设置限制了上传大小.这个时候Web.Config中 ...

  4. python之callable

    callback是python的内置函数 英文说明: callable(object) Return True If the object argument appears callable,Fals ...

  5. MD5加密 和 自定义加密解密

    public class EncryptString { /// <summary> /// MD5加密 /// </summary> /// <param name=& ...

  6. Node.js中package.json中库的版本号详解(^和~区别)

    当我们查看package.json中已安装的库的时候,会发现他们的版本号之前都会加一个符号,有的是插入符号(^),有的是波浪符号(~).那么他们到底有什么区别呢?先贴一个例子,对照例子来做解释: &q ...

  7. H-Updating a Dictionary (模拟)

    In this problem, a dictionary is collection of key-value pairs, where keys are lower-case letters, a ...

  8. python学习第五十天shutil模块的用法

    什么shutil模块,就是对高级的文件,文件夹,压缩包进行处理的模块,下面简单讲述其用法. 文件和文件夹的操作 拷贝文件内容 import shutil shutil.copyfileobj(open ...

  9. 【JAVA】input.next().charAt(0);的含义

    接收键盘输入的字符串,并且取出它的第一个字符. 分析: Scanner scan=new Scanner(System.in); String s=scan.next(); //返回一个String ...

  10. 20191202IIS

    IIS和.netfw4.0安装顺序是从前到后,如果不小心颠倒了,无所谓. 打开程序-运行-cmd:输入一下命令重新注册IIS C:\WINDOWS\Microsoft.NET\Framework\v4 ...