题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4104

想了很久,想出一个 nlogn (也许是 n2logn )的,可惜空间是 n2

已知字符集,对它排个序,对应上给出的那些字符,就能知道每个字符前面是哪个字符。

这样得到了一些长度为2的串。这些长度为2的串一定也是这 n+1 行的开头;所以对它们排序后对应上给出的那些字符,就能得到长度为3的串。这样就能得到答案。

但是太慢。考虑已知长度为 k 的串,想一下把它接成 2*k 的串。

发现如果已经接好了,则对 2*k 的串排序,它们的前 k 个字符的顺序就和现在看见的长度为 k 的串的顺序一样。

所以对现在的长度为 k 的串排序,并再保留排序前的样子,然后考虑排序后的每个串接到排序前的哪个串上。

发现对长度为 2*k 的串排序就是以长度为 k 时排序前的串为第一关键字、长度为 k 的排序后的串为第二关键字的。

所以将长度为 k 的串排序后,已知每个串的上一个字符是什么;从前到后枚举排序后的长度为 k 的串,找到以该串对应字符结尾的那些串,在这个类别里找到第一个还没被接上的串,把自己接到该串后面。

这样一共 logn 层,每层大概是 O(n) ?不过还没想好怎么实现“接上去”,也许每层要变成 n2 了。

然后看了题解。

已知字符集和每个字符后面接着的那个串的字典序。

所以可以得到后面的那个串前面接上该字符后的新串的字典序。(形如“一个字符+一个串",并且已知“一个串”的不算那个字符时的字典序排名)

同时由给出的那些字符,把新串按字典序对应上,就能知道每个新串的上一个字符是什么。

“上一个字符+一个串”的样子就是一个新串的样子。所以知道这个新串对应的上一个字符,可以尝试直接找这个新串对应的新串。如果能找到的话,得到新的自身排名和上一个字符,就能顺着把原来新串的从最后一个位置开始的每一个“上一个字符”找出来,即找到了原串。

其实问题就在于如果有很多个“同一个字符+一个串”,不知道自己这个串应该接在其中的哪个后面。

但已经知道这些备选方案接着的那个串的字典序排名了;而且也知道自己这个串的字典序排名。所以按排名对应上就行啦!对应上之后又知道了自己串的新的排名和上一个字符,就能做下去了。

自己的思路要维护 n+1 个串,而且每次要排序。没有利用上“前续了一个字符后新串的排名已知”这个条件。

因为每次要前续一个字符,所以把给出的条件从“已知每个排名对应的上一个字符”转为“已知每个字符后面串的排名”,就能实现一直做下去。

看到后缀数组,自己总想着分析它的倍增,而最近这两道题都是从它的“后缀去掉开头字符后仍是一个已知后缀”的角度考虑。学习一下这个思路。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=2e5+;
int n,m,dy[N],prn[N];
struct Node{int a,b;}t[N];
bool operator< (Node u,Node v){return u.a<v.a||(u.a==v.a&&u.b<v.b);}
int rdn()
{
int ret=;bool fx=;char ch=getchar();
while(ch>''||ch<''){if(ch=='-')fx=;ch=getchar();}
while(ch>=''&&ch<='')ret=ret*+ch-'',ch=getchar();
return fx?ret:-ret;
}
int main()
{
n=rdn();m=rdn();
for(int i=,d;i<=n+;i++)
{
t[i].a=rdn(); t[i].b=i;
}
sort(t+,t+n+);
for(int i=;i<=n+;i++)dy[t[i].b]=i;
int cr=,bj=n;
while(bj)
{
cr=dy[cr];prn[bj--]=t[cr].a;
}
for(int i=;i<=n;i++)printf("%d ",prn[i]);puts("");
return ;
}

bzoj 4104 [Thu Summer Camp 2015]解密运算——思路的更多相关文章

  1. 【BZOJ 4104】 4104: [Thu Summer Camp 2015]解密运算 (智商)

    4104: [Thu Summer Camp 2015]解密运算 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 370  Solved: 237 De ...

  2. [Thu Summer Camp 2015]解密运算

    4104: [Thu Summer Camp 2015]解密运算 Time Limit: 10 Sec  Memory Limit: 512 MB Description 对于一个长度为N的字符串,我 ...

  3. bzoj:4105: [Thu Summer Camp 2015]平方运算

    Description   Input 第一行有三个整数N,M,p,分别代表序列的长度.平方操作与询问操作的总次数以及在平方操作中所要模的数.   接下来一行N个数代表一开始的序列{X1,X2,... ...

  4. BZOJ4104:[Thu Summer Camp 2015]解密运算——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=4104 对于一个长度为N的字符串,我们在字符串的末尾添加一个特殊的字符".".之 ...

  5. bzoj4104 [Thu Summer Camp 2015]解密运算

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4104 [题解] 脑洞+找规律做出来的.. 我用样例作为说明吧 样例给了我们这个 AAAC.A ...

  6. BZOJ4104 [Thu Summer Camp 2015]解密运算 【乱搞】

    题目链接 BZOJ4104 题解 我们将已知字符排序,由循环就可以得到一个对应关系 如样例就是: 0->第5行 1->第1行 1->第2行 1->第3行 1->第5行 2 ...

  7. [BZOJ 4103] [Thu Summer Camp 2015] 异或运算 【可持久化Trie】

    题目链接:BZOJ - 4103 题目分析 THUSC滚粗之后一直没有写这道题,从来没写过可持久化Trie,发现其实和可持久化线段树都是一样的.嗯,有些东西就是明白得太晚. 首先Orz ZYF-ZYF ...

  8. BZOJ 4103: [Thu Summer Camp 2015]异或运算 可持久化trie

    开始想了一个二分+可持久化trie验证,比正解多一个 log 仔细思考,你发现你可以直接按位枚举,然后在可持久化 trie 上二分就好了. code: #include <bits/stdc++ ...

  9. 4105: [Thu Summer Camp 2015]平方运算

    首先嘛这道题目只要知道一个东西就很容易了:所有循环的最小公约数<=60,成一条链的长度最大为11,那么我们就可以用一个很裸的方法.对于在链上的数,我们修改直接暴力找出并修改.对于在环上的数,我们 ...

随机推荐

  1. Kotlin 卸载APP自身

    package com.example.batdw01.myapplication import android.net.wifi.WifiManager import android.support ...

  2. 使用shiro缓存用户身份信息的时候报:java.io.NotSerializableException: org.apache.shiro.util.SimpleByteSource

    最近在使用shiro缓存用户的身份信息的时候,报了simpleByteSource不能序列化,跟进源码一看,原来这个类没有实现序列化的接口,但是我在缓存身份信息的实现又要用到这个类,解决方法:重写一个 ...

  3. SpringBoot2.0之整合ElasticSearch

    就类比数据库到时候去实现 服务器端配置 集群名字  与yml名字一致 pom: <project xmlns="http://maven.apache.org/POM/4.0.0&qu ...

  4. java-四则运算二

    1.实验目的:是否有乘除法,括号,多项式运算. 2.思路:利用简单的循环switch语句进行循环输出随机数 3.程序源代码: package jiajianchengchu; import java. ...

  5. Java动态代理的总结

    最近和一个好友在聊起Mybatis时,他问用Mybatis我们只是配置好mapper,然后写dao层接口就实现了dao层方法.然后我说我觉得用动态代理可以实现.然后他又说感觉动态代理和外观模式没什么区 ...

  6. PHP 环境搭建(win7+php5.6+apache或nginx)

    安装介质 PHP5.6.16(php-5.6.16-Win32-VC11-x64.zip) Apache2.4.18(httpd-2.4.18-win64-VC14.zip) nginx (nginx ...

  7. 剑指offer--37.和为S的两个数字

    链接:https://www.nowcoder.com/questionTerminal/390da4f7a00f44bea7c2f3d19491311b来源:牛客网@华科渣硕 不要被题目误导了!证明 ...

  8. LitJson使用中需要注意的一些问题(转)

    LitJson使用中需要注意的一些问题 使用C#做Untiy开发时,有解析Json的需求,选择使用了LitJson这个库,因为之前我们是使用lua的,这个库会将Json解析后保存为JsonData,这 ...

  9. PostgreSQL 日常SQL记录

    平时用的比较多的SQL语句,有时候会忘掉一点点,在这里记录一下: 1.创建表的同时,插入数据: create table test as select generate_series(1, 10000 ...

  10. PostBack IsPostBack

    这涉及到aspx的页面回传机制的基础知识 postback是回传 即页面在首次加载后向服务器提交数据,然后服务器把处理好的数据传递到客户端并显示出来,就叫postback, ispostback只是一 ...