[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小时太少,我的题目很良心,都很简单. 答案可以在模拟测试 ...
随机推荐
- mysql-1.1基础
笔记内容:mysql基础,创建数据库,创建表,操作数据表,操作数据,简单查询,条件查询,排序,分组,聚合,连接查询(等值连接,内连接,外链接),子查询 自己提示:脑图笔记存于网盘中 右键:新标签页打 ...
- mongoDB数据库文件路径和数据操作
1.查看MongoDB在电脑上的安装路径 which mongod 2.默认mongodb 数据文件是放到根目录 data/db 文件夹下,如果没有这个文件,需要自行创建 mkdir -p /data ...
- 104、验证Swarm数据持久性 (Swarm11)
参考https://www.cnblogs.com/CloudMan6/p/8016994.html 上一节我们成功将 nfs 的volume挂载到 Service上,本节验证 Failover时 ...
- 06 Django之模型层---多表操作
一 创建模型 表和表之间的关系 一对一.多对一.多对多 ,用book表和publish表自己来想想关系,想想里面的操作,加外键约束和不加外键约束的区别,一对一的外键约束是在一对多的约束上加上唯一约束. ...
- Tcp之心跳包
Tcp之心跳包 心跳包 跳包之所以叫心跳包是因为:它像心跳一样每隔固定时间发一次,以此来告诉服务器,这个客户端还活着. 事实上这是为了保持长连接,至于这个包的内容,是没有什么特别规定的,不过一般都是很 ...
- Java缓存要点
1.缓存一般是这样的:先查缓存,查不到就查DB,如果DB查不到就结束,DB查到了就写入缓存. 如果用户一直在大量地查询不存在的数据,则所有的请求都会落到DB,而且没有数据写入缓存. 解决方法:把查不到 ...
- Delphi FileListBox组件
- linux系统设置登录失败n次锁定账户:vim /etc/pam.d/system-auth
auth required pam_env.so 登陆后的环境变量 auth sufficient pam_fprintd.so 指纹认证 auth sufficient pam_unix.so nu ...
- shell 获取结果中的第n列,第n行
ls -l | awk '{print $5}' | sed -n '2p' awk 是很实用的文本处理命令,print 到后带的是你要获取第几列,sed -n 是指定第几行.
- MST-kruskal ElogE+V
hdu 1233 #include<stdio.h> #include<algorithm> using namespace std; struct dis { int a, ...