题目传送门(内部题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$分。


代码时刻

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int T,C,M,L,S[100010];
  4. int ans[5],a[5],maxn;
  5. pair<int,int> pos[100001];
  6. pair<int,int> pre;
  7. void pre_work()
  8. {
  9. memset(ans,0x3f,sizeof(ans));
  10. L=0;
  11. }
  12. void check(int x)
  13. {
  14. pre=make_pair(0,0);
  15. memset(S,0,sizeof(S));
  16. memset(a,0,sizeof(a));
  17. maxn=0;
  18. for(int i=1;i<=M;i++)
  19. {
  20. int flag=(pos[i].first-1)%x+1;
  21. if(S[flag]&&S[flag]!=pos[i].second)return;
  22. S[flag]=pos[i].second;
  23. }
  24. for(int i=1;i<=L;i++)
  25. {
  26. if(!S[i])continue;
  27. if(S[i]<maxn){L=0;return;}
  28. maxn=max(maxn,S[i]);
  29. a[S[i]]=max(a[S[i]],i);
  30. }
  31. a[C]=x;
  32. for(int i=1;i<=C;i++)
  33. {
  34. if(!a[i])a[i]=a[i-1]+1;
  35. if(a[i]<=a[i-1])return;
  36. }
  37. for(int i=C;i>=2;i--)a[i]=a[i]-a[i-1];
  38. for(int i=1;i<=C;i++)
  39. {
  40. if(a[i]>ans[i])return;
  41. else if(a[i]<ans[i])
  42. {
  43. for(int j=1;j<=C;j++)ans[j]=a[j];
  44. return;
  45. }
  46. }
  47. }
  48. int main()
  49. {
  50. scanf("%d%d",&T,&C);
  51. while(T--)
  52. {
  53. pre_work();
  54. scanf("%d",&M);
  55. for(int i=1;i<=M;i++)
  56. {
  57. int x,y;
  58. scanf("%d%d",&x,&y);
  59. pos[i]=make_pair(x,y+1);
  60. L=max(L,x+C);
  61. }
  62. for(int i=C;i<=L;i++)check(i);
  63. if(ans[1]>1000000000)puts("NO");
  64. else{for(int i=1;i<=C;i++)printf("%d ",ans[i]);puts("");}
  65. }
  66. return 0;
  67. }

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. 【CF906E】Reverses(回文自动机,最小回文分割)

    题意:给定两个长度相等的仅由小写字母组成的串A和B,问在A中最少选择多少段互不相交的子串进行翻转能使A和B相同 len<=5e5 思路:构造新串S=a[1]b[1]a[2]b[2]...a[n] ...

  2. 资源-DotNet-站点:DotNet 站点列表

    ylbtech-资源-DotNet-站点:DotNet 站点列表 1.ASP.NET Web返回顶部 1.1.问卷星 https://www.wjx.cn/sample/service.aspx 1. ...

  3. SSAS MDX语句 期末查询简单示例

    WITH Member [Measures].[num Last Day of Month] AS( [时间].[YQMD].CurrentMember.LastChild,[Measures].[门 ...

  4. 高并发之CAS机制和ABA问题

    什么是CAS机制 CAS是英文单词Compare and Swap的缩写,翻译过来就是比较并替换 CAS机制中使用了3个基本操作数:内存地址V,旧的预期值A,要修改的新值B. 看如下几个例子: pac ...

  5. delphi在64位系统下写注册表注意事项

    HKEY_LOCAL_MACHINE写这个主键下的项,在64位系统下可能会重定向,所以构造时要加KEY_WOW64_64KEY reg := TRegistry.Create(KEY_WRITE or ...

  6. 数论---lcm和gcd

    cd即最大公约数,lcm即最小公倍数. 首先给出a×b=gcd×lcm 证明:令gcd(a,b)=k,a=xk,b=yk,则a×b=xykk,而lcm=xyk,所以ab=gcd*lcm. 所以求lcm ...

  7. 迪杰斯特拉算法(Dijkstra)

    模板一: 时间复杂度O(n2) int dijkstra(int s,int m) //s为起点,m为终点 { memset(dist,,sizeof(dist)); //初始化,dist数组用来储存 ...

  8. UVALive 4728 Squares(旋转卡壳)

    Squares The famous Korean IT company  plans to make a digital map of the Earth with help of wireless ...

  9. 【问题解决方案】本地仓库删除远程库后添加到已有github仓库时仓库地址找不到的问题(github仓库SSH地址)

    参考: 我参考我自己.jpg 背景: 想添加一下远程库,github主页找了半天,Google搜索了半天,都没有找到,所以这里写一个,记录一下 1-格式分析:git@github.com:用户名/仓库 ...

  10. java 多线程 线程安全及非线程安全的集合对象

    一.概念: 线程安全:就是当多线程访问时,采用了加锁的机制:即当一个线程访问该类的某个数据时,会对这个数据进行保护,其他线程不能对其访问,直到该线程读取完之后,其他线程才可以使用.防止出现数据不一致或 ...