[CSP-S模拟测试]:真相(模拟)
题目传送门(内部题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模拟测试]:真相(模拟)的更多相关文章
- 模拟测试—moq:简单一两句
在Xunit的基础上,说话模拟测试. 假如我们有这样一个控制器里面有这样一个方法,如图 我们在对Bar测试得时候,如果测试未通过,错误有可能来至于Bar,也有可能错误来至于serverde Foo方法 ...
- csp-s模拟测试95
csp-s模拟测试95 去世场祭. $T1$:这不裸的除法分块吗. $T2$:这不裸的数据结构优化$Dp$吗. $T3$:这不裸的我什么都不会搜索骗$30$分吗. 几分钟后. 这除法分块太劲了..(你 ...
- Android单元测试与模拟测试详解
测试与基本规范 为什么需要测试? 为了稳定性,能够明确的了解是否正确的完成开发. 更加易于维护,能够在修改代码后保证功能不被破坏. 集成一些工具,规范开发规范,使得代码更加稳定( 如通过 phabri ...
- [开源]微信在线信息模拟测试工具(基于Senparc.Weixin.MP开发)
目前为止似乎还没有看到过Web版的普通消息测试工具(除了官方针对高级接口的),现有的一些桌面版的几个测试工具也都是使用XML直接请求,非常不友好,我们来尝试做一个“面向对象”操作的测试工具. 测试工具 ...
- 安装nginx python uwsgi环境 以及模拟测试
uwsgi帮助文档: http://uwsgi-docs-cn.readthedocs.io/zh_CN/latest/WSGIquickstart.html http://uwsgi-docs.re ...
- 利用Python中的mock库对Python代码进行模拟测试
这篇文章主要介绍了利用Python中的mock库对Python代码进行模拟测试,mock库自从Python3.3依赖成为了Python的内置库,本文也等于介绍了该库的用法,需要的朋友可以参考下 ...
- 转 C#实现PID控制的模拟测试和曲线绘图
C#实现PID控制的模拟测试和曲线绘图 本文分两部分,一部分是讲PID算法的实现,另一部分是讲如何用动态的曲线绘制出PID运算的结果. 首先,PID算法的理论模型请参考自动控制理论,最早出现的是模 ...
- Mockito:一个强大的用于Java开发的模拟测试框架
https://blog.csdn.net/zhoudaxia/article/details/33056093 介绍 本文将介绍模拟测试框架Mockito的一些基础概念, 介绍该框架的优点,讲解应用 ...
- NOIP模拟测试1(2017081501)
好,今天是cgg第一次举行模拟测试,希望各位支持. 时间限制:2小时 题目链接: 题目一:水得都没名字了 题目二:车站 题目三:选数 不要觉得2小时太少,我的题目很良心,都很简单. 答案可以在模拟测试 ...
随机推荐
- java 如何编写多线程的代码
线程是干活的所以线程一定是Thread,或者改线程实现Runnable接口多线程是竞争关系,所以多个线程竞争同一个资源,也就是同一个对象所以这个竞争对象发到Thread中即: // resources ...
- 一、程序安全-SQL注入漏洞
先新建MYDB.MDF,表MyUser: 测试页面: 一.利用报错获取信息 操作:按姓名精确查询,在输入框输入:小卫' and 1=db_name()/0 and '1'='1执行语句:select ...
- 学会这 2 点,轻松看懂 MySQL 慢查询日志
MySQL中的日志包括:错误日志.二进制日志.通用查询日志.慢查询日志等等.这里主要介绍下比较常用的两个功能:通用查询日志和慢查询日志. 1)通用查询日志:记录建立的客户端连接和执行的语句. 2)慢查 ...
- 11 Python之初识函数
---恢复内容开始--- 1. 什么是函数? f(x) = x + 1 y = x + 1 函数是对功能或者动作的封装 2. 函数的语法和定义 def 函数名(): 函数体 调用: 函数名() 3. ...
- 谷歌浏览器(Chrome)离线包的下载方法!
谷歌浏览器(Chrome)其实可以下载离线包,用离线包安装的好处,就是一次获得全部安装文件,不需要漫长的在线下载过程了! 下载地址:https://www.google.com/chrome/eula ...
- dede_arctype|栏目表
dede_arctype|栏目表: 字段 类型 整理 属性 Null 默认 额外 id smallint(5) UNSIGNED 是 NULL 栏目ID reid smallint(5) UNSIGN ...
- busybox介绍
BusyBox 是一个集成了一百多个最常用linux命令和工具的软件.BusyBox 将许多具有共性的小版本的UNIX工具结合到一个单一的可执行文件.这样的集合可以替代大部分常用工具比如的GNU fi ...
- Linux中断流程分析
裸机中断: 1.中断流入口 2.事先注册中断处理程序 3.根据中断源编号,调取处理程序 irq_svc:1.等到产生中断源的编号(每一个中断号都有一个描述结构) 2.
- hdu1864最大报销额 01
先把小数乘100变成整数然后处理每个发票里面可以报销的 最后自底向上DP #include <stdio.h> #include <algorithm> #include &l ...
- [uboot] (第四章)uboot流程——uboot编译流程 (转)
以下例子都以project X项目tiny210(s5pv210平台,armv7架构)为例 [uboot] uboot流程系列:[project X] tiny210(s5pv210)上电启动流程(B ...