[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小时太少,我的题目很良心,都很简单. 答案可以在模拟测试 ...
随机推荐
- Python 入门 之 类的约束以及super()剖析
Python 入门 之 类的约束以及super()剖析 1.类的约束 第一版: class WechatPay: def pay(self): print("微信支付") clas ...
- 在Windows下安装BIND作为DNS服务器(模拟网站比较有用)
本文参考了CU下的一篇帖子,感谢:) 1.下载BIND http://ftp.isc.org/isc/bind9/9.4.3/BIND9.4.3.zip 2.安装 下载回来是zip的压缩包,解压 ...
- WPF中Matrix介绍
最近在做一些图形变换操作的功能,图形变换涉及大学中的矩阵运算部分的知识,又重新复习了一下矩阵.这里做一下记录.由于不知道矩阵如何输入,一个个截图又麻烦,所以这里就全部用截图了^-^.
- 导出excel-NPOI
前台调用: view: <a href='/Admin/NurseUser/Excel' target='_blank'>导出Excel</a>或js: window.loca ...
- 用原生js来写一个swiper滑块插件
是不是有点印象了,没错,他的最基本的用法就是左右滑动,插件使用者只需要写几行简单的html和js即可实现一个简单滑动效果,不过你完全可以组合各种元素来适应不同的场景. 当然插件我已经写好了,咱 ...
- iOS用contenteditable滚动时,光标不会刷新定位的处理方法
分析 iOS的 wkwebview 在滚动时会暂停许多动画,作为优化 解决思路 监听滚动事件,利用文档重绘即可刷新动画 ps:因为滚动有惯性,touchmove事件只能监听到手指松开的那一刻,所以只能 ...
- MySQL5.7修改数据库目录!
MySQL5.7默认安装,修改之前,停止MySQL服务. 数据库目录:C:\ProgramData\MySQL\MySQL Server 5.7\Data 配置文件:C:\ProgramData\My ...
- Java构造二叉树、树形结构先序遍历、中序遍历、后序遍历
package com.example.demo; public class BTree { public int data; public BTree left; public BTree rigt ...
- 2019-11-29-asp-dotnet-core-通过图片统计-csdn-用户访问
title author date CreateTime categories asp dotnet core 通过图片统计 csdn 用户访问 lindexi 2019-11-29 08:26:58 ...
- tornado实现高并发爬虫
from pyquery import PyQuery as pq from tornado import ioloop, gen, httpclient, queues from urllib.pa ...