题目传送门(内部题106)


输入格式

  第一行为一个正整数$T$,表示数据组数。
  接下来$T$组数据,每组数据第一行一个正整数$n$表示$OIer$,接下来$n$行,第$i$行表示编号为$i$的人所说的话,格式可以参考题面描述。


输出格式

  对每组数据,如果这组数据里的$OIer$们说的话无论如何都会产生矛盾,那么就输出一行一个字符串$inconsistent$,否则输出一行一个字符串$consistent$。


样例

样例输入:

3
3
+
+
$ 3
3
+
-
$ 3
1
-

样例输出:

consistent
consistent
inconsistent


数据范围与提示

样例解释:

  第一组数据中,三个人全部说真话可以满足条件。
  第二组数据中,前两个人说真话,第三个人说假话可以满足条件(这时候一共有$2$个人说了真话,第三个人的描述自然不正确)
  第三组数据中,一名无聊的$OIer$一个人产生了一个“这句话是假话”的悖论,因此无论如何他所说的话都自相矛盾。

数据范围:

  对于$30\%$的数据,$n,T\leqslant 10$。
  对于$65\%$的数据,$n\leqslant 1,000$。
  对于$100\%$的数据,$1\leqslant n,T\leqslant 100,000$,每个测试点内$n$的和不超过$1,000,000$。


题解

如果没有第一种情况,那么可以假设第一个人说的是实话,然后暴力判断就好了。

现在考虑如何处理有第一种情况的情况。

如果一个人出现了第一种情况,那么直到上一个出现第一种情况的人之间这一段就已经被确认了,而这个人说话的真实性只有两种情况,如果他说的是正确的,那么与他同种(都是第一种情况,且$k$一样)的人也说的是对的,其余都是错的,所以可以预处理出来这个人说真话和说假话时该段说真话和说假话的人数。

注意细节即可。

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

期望得分:$100$分。

实际得分:$100$分。


代码时刻

#include<bits/stdc++.h>
using namespace std;
struct rec{int opt,k;}e[100001];
int n;
vector<int> vec;
int num[2][100001],fail,f[2][100001],con[100001];
void pre_work(){fail=0;vec.clear();}
int main()
{
int T;scanf("%d",&T);
while(T--)
{
pre_work();
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
char ch[3];
scanf("%s",ch+1);
switch(ch[1])
{
case '$':e[i].opt=1;scanf("%d",&e[i].k);vec.push_back(i);break;
case '+':e[i].opt=2;break;
case '-':e[i].opt=3;break;
}
}
if(!vec.size())
{
bool now=1;
for(int i=1;i<=n;i++)if(e[i].opt==3)now^=1;
if(now)puts("consistent");
else puts("inconsistent");
continue;
}
int sum=0;
for(int i=0;i<vec.size();i++)
{
int pos=vec[i]+1,nxt,now=1,cnt=0,tot=1;
if(pos>n)pos-=n;
if(i==vec.size()-1)nxt=vec[0];
else nxt=vec[i+1];
for(int j=pos;j!=nxt;)
{
if(now)cnt++;
if(e[j].opt==3)now^=1;
tot++;j++;if(j>n)j-=n;
}
con[++fail]=e[nxt].k;
if(now)
{
cnt++;
num[0][fail]=cnt;
num[1][fail]=tot-cnt;
}
else
{
num[0][fail]=tot-cnt;
num[1][fail]=cnt;
}
f[0][con[fail]]+=num[0][fail];
f[1][con[fail]]+=num[1][fail];
sum+=num[1][fail];
}
bool ans=0;
for(int i=0;i<=n;i++)
{
int cnt=f[0][i]-f[1][i]+sum;
if(cnt==i){ans=1;break;}
}
if(ans)puts("consistent");
else puts("inconsistent");
for(int i=1;i<=fail;i++)f[0][con[i]]=f[1][con[i]]=0;
}
return 0;
}

rp++

[CSP-S模拟测试]:真相(模拟)的更多相关文章

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

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

  2. csp-s模拟测试95

    csp-s模拟测试95 去世场祭. $T1$:这不裸的除法分块吗. $T2$:这不裸的数据结构优化$Dp$吗. $T3$:这不裸的我什么都不会搜索骗$30$分吗. 几分钟后. 这除法分块太劲了..(你 ...

  3. Android单元测试与模拟测试详解

    测试与基本规范 为什么需要测试? 为了稳定性,能够明确的了解是否正确的完成开发. 更加易于维护,能够在修改代码后保证功能不被破坏. 集成一些工具,规范开发规范,使得代码更加稳定( 如通过 phabri ...

  4. [开源]微信在线信息模拟测试工具(基于Senparc.Weixin.MP开发)

    目前为止似乎还没有看到过Web版的普通消息测试工具(除了官方针对高级接口的),现有的一些桌面版的几个测试工具也都是使用XML直接请求,非常不友好,我们来尝试做一个“面向对象”操作的测试工具. 测试工具 ...

  5. 安装nginx python uwsgi环境 以及模拟测试

    uwsgi帮助文档: http://uwsgi-docs-cn.readthedocs.io/zh_CN/latest/WSGIquickstart.html http://uwsgi-docs.re ...

  6. 利用Python中的mock库对Python代码进行模拟测试

    这篇文章主要介绍了利用Python中的mock库对Python代码进行模拟测试,mock库自从Python3.3依赖成为了Python的内置库,本文也等于介绍了该库的用法,需要的朋友可以参考下     ...

  7. 转 C#实现PID控制的模拟测试和曲线绘图

    C#实现PID控制的模拟测试和曲线绘图   本文分两部分,一部分是讲PID算法的实现,另一部分是讲如何用动态的曲线绘制出PID运算的结果. 首先,PID算法的理论模型请参考自动控制理论,最早出现的是模 ...

  8. Mockito:一个强大的用于Java开发的模拟测试框架

    https://blog.csdn.net/zhoudaxia/article/details/33056093 介绍 本文将介绍模拟测试框架Mockito的一些基础概念, 介绍该框架的优点,讲解应用 ...

  9. NOIP模拟测试1(2017081501)

    好,今天是cgg第一次举行模拟测试,希望各位支持. 时间限制:2小时 题目链接: 题目一:水得都没名字了 题目二:车站 题目三:选数 不要觉得2小时太少,我的题目很良心,都很简单. 答案可以在模拟测试 ...

随机推荐

  1. springboot读取配置不存在报错

    @Value("${log.regId}")private String regId = "123123"; String regId = env.getPro ...

  2. 在CentOS 7系统下升级 Jenkins版本

    使用yum方式安装的war文件路径:/usr/lib/jenkins/jenkins.war 查看war包所在的目录 find / -name jenkins.war 停止Jenkins 服务 sys ...

  3. 实现Promise类

    基本使用: let promise = new Promise((resolve, reject) => { // do something if (true) { resolve('succe ...

  4. 笔记本电脑重装win7/win10系统教程

    由于笔记本第一次重装系统会出现系统装不上,还有出现找不到有效硬盘分区,等等问题,然后这篇文章主要讲解BIOS设置的方法,用此BIOS设置,电脑用原本安装系统的方式,能有效地解决以上问题,这有两种方法解 ...

  5. cassandra分页

    在cassandra的协议中,没有具体规定查询结果的行数限制.但是对于大的数据集,依然有结果分页的必要.过大的结果集会爆掉服务端或者客户端的内存. 传统的分页方法采用了一点trick,采用了token ...

  6. 3.flask核心与源码剖析

    1.session session存储了特定用户会话所需的属性及配置信息,这样,当用户在应用程序的 Web 页之间跳转时,存储在 session 对象中的变量将不会丢失,而是在整个用户会话中一直存在下 ...

  7. Vivado添加sublime text编辑器

    我们当用vivado会发现文本编辑器有点鸡肋,没有自动的缩进的功能,所以我想用sublime来进行文本的编辑,下面就是绑定的一些方法(但是呢其实吧,虽然可以绑定却不能实时的报错,,,我感觉我还是老老实 ...

  8. Android单元测试之google官例CalculatorTest

    执行测试用例类CalculatorTest     设置genymotion可见: Android Studio界面中,依次单击菜单项 View >Toolbar.即可见改工具按钮. 启动gen ...

  9. CRM项目讲解和django知识点回顾

    今天想把之前写的CRM项目梳理下,顺便回顾一下djiango的部分重要知识. 1.登录页面(包含简单验证码) 首先来看下CRM的登录页面,样式啥的不重要,大家可以去jquery ui的网站上或者其他地 ...

  10. 标准C语言(8)

    指针变量用来记录地址数据,指针变量的用途就是找到另外一个变量,没有记录有效地址的指针不能用来找到其它变量,声明指针变量时必须在变量名称前写*.如果一个指针变量记录了另外一个变量的地址就可以认为它们之间 ...