spoj SUBLEX (Lexicographical Substring Search) RE的欢迎来看看

SPOJ.com - Problem SUBLEX

  这么裸的一个SAM,放在了死破OJ上面就是个坑。

注意用SAM做的时候输出要用一个数组存下来,然后再puts,不然一个一个字符输出会更慢。

还有一个就是不要多数据输入,估计最后多了几个没用的数字,反正我这么做一直无端端的RE。(就这样浪费了我一天好么!出数据的人这么不负责!)

最后就是,第k大的k是会超过子串数的。(这什么脑残配置?)

  综上,这题除了坑就是坑。

 

代码如下:

 

  1 #include <bits/stdc++.h>
  2 using namespace std;
  3 
  4 const int N = 222222;
  5 const int LAST = 90000;
  6 const int K = 26;
  7 
  8 struct Node {
  9     Node *nx[K], *fail;
 10     int dist;
 11     long long sub;
 12 
 13     void Clear(const int d = 0) {
 14         memset(nx, 0, sizeof nx);
 15         fail = 0;
 16         dist = d;
 17         sub = 0;
 18     }
 19 } ;
 20 
 21 struct SAM {
 22     Node node[N << 1];
 23     Node *root, *last;
 24     int ttNode;
 25 
 26     Node *Mem(const int d = 0) {
 27         Node *temp = node + ttNode++;
 28 
 29         temp->Clear(d);
 30 
 31         return temp;
 32     }
 33 
 34     void Clear() {
 35         ttNode = 0;
 36         root = last = Mem();
 37     }
 38 
 39     void Expand(const char c) {
 40         const int idx = c - 'a';
 41         Node *p = last, *np = Mem(p->dist + 1);
 42 
 43         for ( ; p && p->nx[idx] == 0; p = p->fail) {
 44             p->nx[idx] = np;
 45         }
 46         if (p) {
 47             Node *q = p->nx[idx];
 48 
 49             if (p->dist + 1 != q->dist) {
 50                 Node *nq = Mem();
 51 
 52                 *nq = *q;
 53                 nq->dist = p->dist + 1;
 54                 q->fail = np->fail = nq;
 55                 for ( ; p && p->nx[idx] == q; p = p->fail) {
 56                     p->nx[idx] = nq;
 57                 }
 58             } else {
 59                 np->fail = q;
 60             }
 61         } else {
 62             np->fail = root;
 63         }
 64         last = np;
 65     }
 66 
 67     int dist[N << 1];
 68     Node *ptr[N << 1];
 69 
 70     void GetSub() {
 71         memset(dist, 0, sizeof dist);
 72         for (int i = 0; i < ttNode; ++i) {
 73             ++dist[node[i].dist];
 74         }
 75         for (int i = 1; i < ttNode; ++i) {
 76             dist[i] += dist[i - 1];
 77         }
 78         for (int i = 0; i < ttNode; ++i) {
 79             ptr[--dist[node[i].dist]] = node + i;
 80         }
 81         for (int i = ttNode - 1; i >= 0; --i) {
 82             Node *p = ptr[i];
 83 
 84             p->sub = 1;
 85             for (int j = 0; j < K; ++j) {
 86                 if (p->nx[j]) {
 87                     p->sub += p->nx[j]->sub;
 88                 }
 89             }
 90         }
 91         --node[0].sub;
 92         //for (int i = 0; i < ttNode; ++i) { cout << node[i].dist << ' '; } cout << endl;
 93         //for (int i = 0; i < ttNode; ++i) { cout << node[i].sub << ' '; } cout << endl;
 94         //for (int i = 0; i < ttNode; ++i) { cout << i << ": "; for (int j = 0; j < K; ++j) { cout << (node[i].nx[j] ? node[i].nx[j] - node : -1) << ' '; } cout << endl; }
 95     }
 96 } sam;
 97 
 98 char s[N], answer[N];
 99 
100 void Generate(char *const s) {
101     srand(time(0));
102     for (int i = 0; i < LAST; ++i) {
103         s[i] = rand() % 26 + 'a';
104     }
105     s[LAST] = 0;
106 }
107 
108 int Run() {
109     //while (~scanf("%s", s)) {
110     //while (1) {
111         //Generate(s);
112         scanf("%s", s);
113         sam.Clear();
114         for (int i = 0; s[i]; ++i) {
115             sam.Expand(s[i]);
116         }
117         sam.GetSub();
118         //cout << sam.root->sub << endl;
119         //if (sam.ttNode >= (N << 1)) { puts("???"); while (1) ; }
120 
121         int n, k;
122 
123         scanf("%d", &n);
124         while (n--) {
125             Node *p = sam.root;
126             int pos = 0;
127 
128             scanf("%d", &k);
129             //if (k > sam.root->sub) { puts("..."); while (1) ; }
130             k = (k - 1) % sam.root->sub + 1;
131             while (k > 0) {
132                 for (int i = 0; i < K; ++i) {
133                     if (p->nx[i] == 0) {
134                         continue;
135                     }
136 
137                     const int cnt = p->nx[i]->sub;
138 
139                     if (cnt >= k) {
140                         //putchar('a' + i);
141                         answer[pos++] = 'a' + i;
142                         p = p->nx[i];
143                         --k;
144                         break;
145                     } else {
146                         k -= cnt;
147                     }
148                 }
149             }
150             answer[pos] = 0;
151             puts(answer);
152             //puts("");
153         }
154     //}
155 
156     return 0;
157 }
158 
159 int main() {
160     //ios::sync_with_stdio(0);
161     return Run();
162 }
View Code

 

UPD:还有更坑的,我开99999 * 2的SAM节点数是会TLE的,开222222 * 2才AC。我猜肯定是新增的数据各种问题,数据不在范围内了。

 

——written by LyonLys

转载于:https://www.cnblogs.com/LyonLys/p/spoj_sublex.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/259884.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mt4双线macd_3年内从亏损90多万到获利近760万,我只坚持我的:60分钟MACD双回拉战法!附选股公式...

MACD指标被普遍认为是最经典实用的技术指标之一。其实并不是因为MACD有多么精妙的算法&#xff0c;而是MACD遵循了最基本的“均线指导原则”&#xff0c;形象的将经典双均线系统换了一种更加直观的表达方式。在MT4中&#xff0c;默认应用的是单线MACD指标&#xff0c;而在证券市…

计算机专业书籍速读方法,格式你玩的转?速读5分钟就懂

小编又接到了新问题&#xff0c;有小伙伴说自己64GB的U盘在电脑里格式化只能选ExFAT或者NTFS&#xff0c;不能选择FAT32&#xff0c;求小编解答&#xff0c;小编正好借着这个机会&#xff0c;说说现在电脑格式问题。如果你懒得读&#xff0c;↓↓↓最后一段有答案&#xff0c;如…

java项目打jar包

http://www.cnblogs.com/tianguook/archive/2012/03/14/2396335.html java项目打jar包分为2种情况&#xff1a; 一、java项目没有导入第三方jar包 这时候打包就比较简单&#xff1a; 1. 首先在Eclipse中打开项目&#xff0c; 右键点击项目&#xff0c;选择“Export”&#xff1…

第一天 :学习node.js

第一天 &#xff1a;学习node.js ① node.js环境配置 我学过的语言最简单的一门 直接百度就可以配置 ② 每个入门 的程序都是从helloworld开始 代码如下 &#xff1a; var httprequire(http); http.createServer(function(req,res){ res.writeHead(200,{content-type:text/htm…

c语言从入门到精通第四版电子书_C语言从入门到精通(吐血分享)4.pdf

C语言从入门到精通(吐血分享)4成功&#xff01;结构体、链表、文件数组、字符串函数、指针三种结构化程序设计三种数据类型、六大表达式一、简单的程序#include 数学函数 命令行main() /*主函数*/{ /*左花括号&#xff0c;函数体的开始 */int a,b,c; /*定义语句*/a 3; /*执行语…

从硬盘上把数据传回到计算机称为什么,计算机基础知识 第一章 习题三

计算机基础知识第一章习题三一、填空题1. 高级语言不能直接被计算机识别并执行&#xff0c;必须翻译成机器语言&#xff0c;翻译的方式有两种&#xff1a;一种是编译方式&#xff0c;另一种是方式。2. 计算机中存储数据的最小单位是&#xff1b;存储容量的基本单位是。3. CAI的…

Mentor PADS 9.5下载安装及破解指南

Pads&#xff0c;是一款用于设计、模拟电子线路及设计电路板的电脑软件&#xff0c;原由Innoveda公司开发&#xff0c;其后改名为PowerPCB&#xff0c;在2002年4月Innoveda被Mentor Graphics收购&#xff0c;近年再次改用原名Pads。目前该软件是国内从事电路设计的工程师和技术…

Thymeleaf 学习笔记 (4)~~~~

2019独角兽企业重金招聘Python工程师标准>>> 模板布局 模板布局主要用到的标记有这么几个&#xff1a; th:fragment &#xff0c;用来定义片段的&#xff0c;用法&#xff1a;th:fragment"fragmentName"&#xff0c;起一个名字方便被其他地方引用&#xf…

凭证 金蝶_金蝶软件账务处理流程之——凭证录入

金蝶是我们财务人非常熟悉的财务软件&#xff0c;但是我们很多财务人只在应用软件的时候还是会出现很多的问题&#xff0c;为了帮助大家更好地应用这个软件&#xff0c;小编今天就来和大家讲讲关于金蝶软件凭证查询环节的一些基本处理流程。点击主界面“凭证查询”→弹出凭证过…

计算机网申兴趣爱好怎么写,银行网申个人特长和兴趣爱好怎么写

银行网申个人特长和兴趣爱好怎么写银行网申中个人简历及兴趣爱好怎么写?下面jyj135小编为大家整理了银行网申中个人特长和兴趣爱好的写作技巧&#xff0c;希望能为大家提供帮助!银行网申特长及兴趣爱好怎么写?特长Strong Point(1)写强项。弱项一定不要写&#xff0c;面试人员…

单例模式讨论篇:单例模式与垃圾回收

出处&#xff1a;http://blog.csdn.net/zhengzhb/article/details/7331354 Jvm的垃圾回收机制到底会不会回收掉长时间不用的单例模式对象&#xff0c;这的确是一个比较有争议性的问题。将这一部分内容单独成篇的目的也是为了与广大博友广泛的讨论一下这个问题。为了能让更多的人…

inline关键字

本文介绍了GCC和C99标准中inline使用上的不同之处。inline属性在使用的时候&#xff0c;要注意以下两点&#xff1a;inline关键字在GCC参考文档中仅有对其使用在函数定义&#xff08;Definition&#xff09;上的描述&#xff0c;而没有提到其是否能用于函数声明&#xff08;Dec…

springmvc 组合注解

组合注解的意思就是一个注解中包含多个注解。在springmvc 的RestController中&#xff0c;你就可发现. Target(ElementType.TYPE) Retention(RetentionPolicy.RUNTIME) Documented Controller ResponseBody public interface RestController {/*** The value may indicate a su…

人才管理是什么意思_上海托管仓库外包仓库管理什么意思

上海托管仓库外包仓库管理什么意思上海仓库托管外包。好的上海仓库托管是预估好自己的货物总计有多少个方。车子的体积有多少&#xff0c;然后估算出总计需要多少车需要多少钱&#xff0c;需要怎么装车、卸货码放方式是什么样的&#xff0c;算出总的费用然后包干给搬家公司。这…

window server 安装与卸载

安装window server 程序:C:\Windows\Microsoft.NET\Framework\v2.0.50727\installutil DataUpdateService.exe net start LuceneServer 卸载window server 程序:net stop LuceneServer C:\Windows\Microsoft.NET\Framework\v2.0.50727\installutil /U DataUpdateService.exe …

Makefile学习(二)[第二版]

复杂实例#示例1:在上一个示例的基础上再增加一个可执行文件03test[修改之处已标红].PHONY: clean all CC gcc CFLAGS -Wall -gBIN 01test 02test 03testSOURCES $(BIN:.c)OBJECTS $(BIN:.o)all: $(BIN)01test: 01test.o02test: 02test.o03test: 03test.o.c.o:$(CC) $(CFLA…

计算机网络asp视频教程,轻轻松松学编程!ASP互动视频教程

从2006年5月18日开始&#xff0c;PConline将与FIF联合推出国内网上第一部互动视频教程&#xff1a;《ASP互动视频教程》。它预示着一个全新的自助学习时代的到来。尽管相较于传统的图文教程&#xff0c;以前的多媒体视频课件优点非常明显&#xff0c;但它仍然存在交互性差的缺点…

Oracle查询和解锁表

一些ORACLE中的进程被杀掉后&#xff0c;状态被置为"killed"&#xff0c;但是锁定的资源很长时间不释放&#xff0c;有时实在没办法&#xff0c;只好重启数据库。现在提供一种方法解决这种问题&#xff0c;那就是在ORACLE中杀不掉的&#xff0c;在OS一级再杀。1.下面…

三维家可以导入别人的方案吗_广州深圳天津形位公差检测三维缺陷检测服务

形位公差检测三维缺陷检测服务标签&#xff1a;形位公差检测 三维缺陷检测服务 三维缺陷检测铸造工艺是一种经济实惠的毛坯成形方式&#xff0c;对于一些形状复杂的零件更能显示出它的经济性。比如汽车发动机的缸体和缸盖&#xff0c;船舶螺旋桨以及精致的艺术品等。本期案例的…

计算机缺失esul.dll,SceneUI.ES.dll

我该如何安装从金山毒霸下载的DLL文件&#xff1f;一&#xff1a;1、从金山毒霸下载压缩文件。2、将DLL文件解压到电脑上的某个地方。3、把该文件跟要求使用它的程序放在同一路径上。注意32位程序需要使用32位的DLL文件&#xff0c;64位程序需要使用64位的DLL文件。否则会出现0…