题目传送门(内部题33)


输入格式

第一行,两个整数$T,C$,表示测试数据组数和字符种类数。
对于每组数据:第一行,一个正整数$M$;接下来的$M$行,每行两个整数$P_k,X_k$($S$的下标从$1$起),保证不会出现$P_{k_1}=P_{k_2}$且$X_{k_1}\neq X_{k_2}$的情况。


输出格式

对于每组数据输出一行,若无解则输出$NO$,若有解则输出对应的$a_0,a_1,...,a_{C−1}$(用空格隔开)。


样例

样例输入:

2 3
3
2 0
3 1
5 2
4
1 0
2 2
3 1
4 2

样例输出:

2 1 2
NO


数据范围与提示

样例解释:

对于第一组数据,可能的答案有$S=0011200112···$和$S=0012200122···$,
分别对应$a_0=2,a_1=2,a_2=1$和$a_0=2,a_1=1,a_2=2$,后者$a$的字典序更小。

数据范围:

对于所有数据,$1\leqslant T\leqslant 5,2\leqslant C\leqslant 4,1\leqslant M\leqslant 10,000,1\leqslant P_i\leqslant 100,000,0\leqslant X_i<C−1$。


题解

又一次没有打正解。

首先,我们要暴力找到一组可行的$S$的长度,从小到大找,但是不要找到了就跳出,因为这样不一定最优。

正解好复杂的,我看不懂……

所以我们考虑剪枝,在我们判当前长度不可行的时候如果是因为$i<j,s_i>s_j$,那么以后肯定不会出现可行长度了,就可以直接输出当前最优答案。

时间复杂度:$\Theta(T\times \max(P_i)^2)$。

期望得分:$60$分。

实际得分:$100$分。


代码时刻

#include<bits/stdc++.h>
using namespace std;
int T,C,M,L,S[100010];
int ans[5],a[5],maxn;
pair<int,int> pos[100001];
pair<int,int> pre;
void pre_work()
{
memset(ans,0x3f,sizeof(ans));
L=0;
}
void check(int x)
{
pre=make_pair(0,0);
memset(S,0,sizeof(S));
memset(a,0,sizeof(a));
maxn=0;
for(int i=1;i<=M;i++)
{
int flag=(pos[i].first-1)%x+1;
if(S[flag]&&S[flag]!=pos[i].second)return;
S[flag]=pos[i].second;
}
for(int i=1;i<=L;i++)
{
if(!S[i])continue;
if(S[i]<maxn){L=0;return;}
maxn=max(maxn,S[i]);
a[S[i]]=max(a[S[i]],i);
}
a[C]=x;
for(int i=1;i<=C;i++)
{
if(!a[i])a[i]=a[i-1]+1;
if(a[i]<=a[i-1])return;
}
for(int i=C;i>=2;i--)a[i]=a[i]-a[i-1];
for(int i=1;i<=C;i++)
{
if(a[i]>ans[i])return;
else if(a[i]<ans[i])
{
for(int j=1;j<=C;j++)ans[j]=a[j];
return;
}
}
}
int main()
{
scanf("%d%d",&T,&C);
while(T--)
{
pre_work();
scanf("%d",&M);
for(int i=1;i<=M;i++)
{
int x,y;
scanf("%d%d",&x,&y);
pos[i]=make_pair(x,y+1);
L=max(L,x+C);
}
for(int i=C;i<=L;i++)check(i);
if(ans[1]>1000000000)puts("NO");
else{for(int i=1;i<=C;i++)printf("%d ",ans[i]);puts("");}
}
return 0;
}

rp++

[CSP-S模拟测试]:字符(模拟+剪枝)的更多相关文章

  1. [CSP-S模拟测试]:字符交换(贪心+模拟)

    题目传送门(内部题136) 输入格式 输入文件第一行为两个正整数$n,k$,第二行为一个长度为$n$的小写字母字符串$s$. 输出格式 输出一个整数,为对字符串$s$进行至多$k$次交换相邻字符的操作 ...

  2. [CSP-S模拟测试]:字符消除2(hash+KMP)

    题目背景 生牛哥终于打通了“字符消除”,可是他又被它的续集难倒了. 题目传送门(内部题52) 输入格式 第一行$n$表示数据组书.接下来每行一个字符串.(只包含大写字母) 输出格式 每组数据输出一个$ ...

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

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

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

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

  5. csp-s模拟测试85

    csp-s模拟测试85 $T1$全场秒切没有什么区分度,$T2$全场成功转化题意但是我并不会打,$T3$暴力都没打很遗憾. 100 00:21:49 02:56:35 02:56:49 135 02: ...

  6. 「题解」NOIP模拟测试题解乱写II(36)

    毕竟考得太频繁了于是不可能每次考试都写题解.(我解释个什么劲啊又没有人看) 甚至有的题目都没有改掉.跑过来写题解一方面是总结,另一方面也是放松了. NOIP模拟测试36 T1字符 这题我完全懵逼了.就 ...

  7. Fiddler: AutoResponder 构建模拟测试场景

    AutoResponder 可用于拦截某一请求,并重定向到本地的资源,或者使用Fiddler的内置响应.可用于调试服务器端代码而无需修改服务器端的代码和配置,因为拦截和重定向后,实际上访问的是本地的文 ...

  8. NOIP模拟测试19「count·dinner·chess」

    反思: 我考得最炸的一次 怎么说呢?简单的两个题0分,稍难(我还不敢说难,肯定又有人喷我)42分 前10分钟看T1,不会,觉得不可做,完全不可做,把它跳了 最后10分钟看T1,发现一个有点用的性质,仍 ...

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

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

随机推荐

  1. 使用Microsoft.Practices.Unity 依赖注入

    Unity是微软Patterns & Practices团队所开发的一个轻量级的,并且可扩展的依赖注入(Dependency Injection)容器,它支持常用的三种依赖注入方式:构造器注入 ...

  2. UE编辑器

    引用ue的js 下载地址http://pan.baidu.com/s/1gdrQ35L <script type="text/javascript" src="__ ...

  3. 使用iconv提示未知错误

    使用iconv 转化编码的时候提示错误:<b>Notice</b>: iconv() [<a href='http://www.jinyuanbao.cn'>fun ...

  4. SSDT and Shadow SSDT table

    参考:http://x86.renejeschke.de/html/file_module_x86_id_313.html http://msdn.microsoft.com/en-us/librar ...

  5. 【读书笔记】:MIT线性代数(5):Four fundamental subspaces

    At the beginning, the difference between rank and dimension: rank is a property for matrix, while di ...

  6. selenium,webdriver模仿浏览器访问百度 基础1

    这是一种比较好的反反爬技术 #安装:pip install selenium=2.48.0 #显示:pip show selenium #卸载:pip uninstall selenium #模拟用户 ...

  7. 比较CGI,FastCGI,PHP-CGI与PHP-FPM的区别

    最早的Web服务器,可以简单地响应浏览器发来的HTTP请求,并将存储在服务器上的HTML文件返回给浏览器,也就是静态html. 随着时间的变化,网站也越来越复杂,所以出现动态技术.但是服务器并不能直接 ...

  8. vue js的简单总结

    这篇文章主要对vue的理解进行总结: 参考来源:http://blog.csdn.net/generon/article/details/72482844 vue.js是一套构建用户界面的渐进式框架, ...

  9. 附: K8S入门系列之集群健康检查

    Kubernetes的kubectl常用命令 1. pod操作 # 获取所有的pod kubectl get pods --all-namespaces -o wide # 使用yaml文件创建pod ...

  10. fusionCharts图表在客户端导出图片

    前提:要具备三个文件:FusionCharts.js / FusionChartsExportComponent.js / FCExporter.swf 1.引用 js 文件 <script t ...