[CSP-S模拟测试]:字符(模拟+剪枝)
题目传送门(内部题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模拟测试]:字符(模拟+剪枝)的更多相关文章
- [CSP-S模拟测试]:字符交换(贪心+模拟)
题目传送门(内部题136) 输入格式 输入文件第一行为两个正整数$n,k$,第二行为一个长度为$n$的小写字母字符串$s$. 输出格式 输出一个整数,为对字符串$s$进行至多$k$次交换相邻字符的操作 ...
- [CSP-S模拟测试]:字符消除2(hash+KMP)
题目背景 生牛哥终于打通了“字符消除”,可是他又被它的续集难倒了. 题目传送门(内部题52) 输入格式 第一行$n$表示数据组书.接下来每行一个字符串.(只包含大写字母) 输出格式 每组数据输出一个$ ...
- 模拟测试—moq:简单一两句
在Xunit的基础上,说话模拟测试. 假如我们有这样一个控制器里面有这样一个方法,如图 我们在对Bar测试得时候,如果测试未通过,错误有可能来至于Bar,也有可能错误来至于serverde Foo方法 ...
- Android单元测试与模拟测试详解
测试与基本规范 为什么需要测试? 为了稳定性,能够明确的了解是否正确的完成开发. 更加易于维护,能够在修改代码后保证功能不被破坏. 集成一些工具,规范开发规范,使得代码更加稳定( 如通过 phabri ...
- csp-s模拟测试85
csp-s模拟测试85 $T1$全场秒切没有什么区分度,$T2$全场成功转化题意但是我并不会打,$T3$暴力都没打很遗憾. 100 00:21:49 02:56:35 02:56:49 135 02: ...
- 「题解」NOIP模拟测试题解乱写II(36)
毕竟考得太频繁了于是不可能每次考试都写题解.(我解释个什么劲啊又没有人看) 甚至有的题目都没有改掉.跑过来写题解一方面是总结,另一方面也是放松了. NOIP模拟测试36 T1字符 这题我完全懵逼了.就 ...
- Fiddler: AutoResponder 构建模拟测试场景
AutoResponder 可用于拦截某一请求,并重定向到本地的资源,或者使用Fiddler的内置响应.可用于调试服务器端代码而无需修改服务器端的代码和配置,因为拦截和重定向后,实际上访问的是本地的文 ...
- NOIP模拟测试19「count·dinner·chess」
反思: 我考得最炸的一次 怎么说呢?简单的两个题0分,稍难(我还不敢说难,肯定又有人喷我)42分 前10分钟看T1,不会,觉得不可做,完全不可做,把它跳了 最后10分钟看T1,发现一个有点用的性质,仍 ...
- [开源]微信在线信息模拟测试工具(基于Senparc.Weixin.MP开发)
目前为止似乎还没有看到过Web版的普通消息测试工具(除了官方针对高级接口的),现有的一些桌面版的几个测试工具也都是使用XML直接请求,非常不友好,我们来尝试做一个“面向对象”操作的测试工具. 测试工具 ...
随机推荐
- 使用Microsoft.Practices.Unity 依赖注入
Unity是微软Patterns & Practices团队所开发的一个轻量级的,并且可扩展的依赖注入(Dependency Injection)容器,它支持常用的三种依赖注入方式:构造器注入 ...
- UE编辑器
引用ue的js 下载地址http://pan.baidu.com/s/1gdrQ35L <script type="text/javascript" src="__ ...
- 使用iconv提示未知错误
使用iconv 转化编码的时候提示错误:<b>Notice</b>: iconv() [<a href='http://www.jinyuanbao.cn'>fun ...
- SSDT and Shadow SSDT table
参考:http://x86.renejeschke.de/html/file_module_x86_id_313.html http://msdn.microsoft.com/en-us/librar ...
- 【读书笔记】:MIT线性代数(5):Four fundamental subspaces
At the beginning, the difference between rank and dimension: rank is a property for matrix, while di ...
- selenium,webdriver模仿浏览器访问百度 基础1
这是一种比较好的反反爬技术 #安装:pip install selenium=2.48.0 #显示:pip show selenium #卸载:pip uninstall selenium #模拟用户 ...
- 比较CGI,FastCGI,PHP-CGI与PHP-FPM的区别
最早的Web服务器,可以简单地响应浏览器发来的HTTP请求,并将存储在服务器上的HTML文件返回给浏览器,也就是静态html. 随着时间的变化,网站也越来越复杂,所以出现动态技术.但是服务器并不能直接 ...
- vue js的简单总结
这篇文章主要对vue的理解进行总结: 参考来源:http://blog.csdn.net/generon/article/details/72482844 vue.js是一套构建用户界面的渐进式框架, ...
- 附: K8S入门系列之集群健康检查
Kubernetes的kubectl常用命令 1. pod操作 # 获取所有的pod kubectl get pods --all-namespaces -o wide # 使用yaml文件创建pod ...
- fusionCharts图表在客户端导出图片
前提:要具备三个文件:FusionCharts.js / FusionChartsExportComponent.js / FCExporter.swf 1.引用 js 文件 <script t ...