题目传送门(内部题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. JavaScript使用readAsDataURL读取图像文件

    JavaScript使用readAsDataURL读取图像文件 FileReader对象的readAsDataURL方法可以将读取到的文件编码成Data URL.Data URL是一项特殊的技术,可以 ...

  2. Django框架——进阶之AJAX

    <script>$("#b1").on("click", function () { // 点击 id是b1的按钮要做的事儿 var i1 = $( ...

  3. Docker容器入门之一:部署SpringBoot项目

    一.环境准备:    1.vm虚拟机: Workstation 12 Pro 12.5.7 build-5813279 2.Centos 7 在虚拟机上安装好Centos7系统后,就可以开始准备安装D ...

  4. 多线程编程-- part 8 CyclicBarrier

    CyclicBarrier简介 cuclicBarrier允许一组线程互相等待,直到到达某个公共屏障点(common barrier point).因为该barrier在释放等待线程后可以重用,所以称 ...

  5. zabbix磁盘的自动发现与磁盘指标监控

    由于最近项目上需要对服务器监控进行规范化监控,再磁盘这块有几种方式 1.如果每台设备的磁盘是一样的 比如都有vda,vdb两块磁盘那么可以采用 1.1 每台客户端写脚本,服务端每台设备去加上监控项(- ...

  6. 点击切换的JS

    $(function(){ var tabnav = $("#tab-nav ul li"); tabnav.click(function(){ $(this).addClass( ...

  7. Linux fing cd 查找文件/文件夹并进入目录命令

    查找文件|文件夹并进入目录命令:cd $() [root@localhost /]# cd $(dirname "`find / -name 'ifcfg-ens33'`") // ...

  8. Coinbase 雇员被 Firefox 0day 漏洞攻击

    Firefox 刚刚修复的 0day 漏洞被用于攻击 Coinbase 雇员.Coinbase 安全团队的 Philip Martin 称,攻击者组合利用了两个 0day 漏洞,其一是远程代码执行漏洞 ...

  9. PAT Basic 1040 有几个PAT (25 分)

    字符串 APPAPT 中包含了两个单词 PAT,其中第一个 PAT 是第 2 位(P),第 4 位(A),第 6 位(T):第二个 PAT 是第 3 位(P),第 4 位(A),第 6 位(T). 现 ...

  10. LIS 普及题

    题意 给你一个长度为 \(n\) 的序列 \(a\). 问是否存在一个长度为 \(L\) 的上升子序列,即存在 \(\{x_1,x_2,...,x_L\}(x_1\lt x_2\lt ...\lt x ...