- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
#include<iostream>
#include<string.h>
#include<utility>
#include<algorithm>
using namespace std;
struct xx
{
string x;
short int d;
int lcp;
};
bool compare(const xx a,const xx b)
{
return a.x<b.x;
}
int findlcp(string a,string b)
{
int i=0,j=0,k=0;
while(i<a.length() && j<b.length())
{
if(a[i]==b[j])
{
k++;
i++;
j++;
}
else
{
break;
}
}
return k;
}
int main()
{
string a="banana";
xx b[100];
a=a+'$';
int len=a.length();
for(int i=0;i<len;i++)
{
b[i].x=a.substr(i);
b[i].d=i+1;
}
sort(b,b+len,compare);
for(int i=0;i<len;i++)
cout<<b[i].x<<" "<<b[i].d<<endl;
b[0].lcp=0;
b[1].lcp=0;
for(int i=2;i<len;i++)
{
b[i].lcp=findlcp(b[i].x,b[i-1].x);
}
for(int i=0;i<len;i++)
cout<<b[i].d<<" "<<b[i].lcp<<endl;
}
这是一个实现 Suffix Array .我在维基百科文章结构中的问题在最坏的情况下给出为 o(n)
所以在我的构造中:
所以对于第一个,即排序
如果我使用计数排序,我可能会减少到 O(n)。如果我使用计数排序是否正确?我的理解是否正确?如果我的理解有误,请告诉我
有没有办法在 O(n) 时间内找到 LCP?
最佳答案
首先,关于您的两个声明:
1) I am sorting all the suffixes of the string using stl sort. This may at least a O(nlogn) in worst case. So here i am violating O(n) construction.
std::sort
的复杂性这里比 O(n log n) 更糟糕。原因是 O(n log n) 假设有 O(n log n) 次单独比较,并且每次比较都在 O(1) 时间内执行。后一种假设是错误的,因为您排序的是字符串,而不是原子项(如字符或整数)。
由于作为主字符串子字符串的字符串项的长度是 O(n),可以肯定地说排序算法的最坏情况复杂度是 O(n2 登录n)。
2) Second one is in constructing a longest common prefix array construction is given O(n).But i think my implementation in O(n^2)
是的,您构建 LCP 数组的时间复杂度为 O(n2),因为您正在运行 lcp
函数 n == len
次,还有你的lcp
函数需要 O(min(len(x),len(y))) 时间来处理一对字符串 x, y。
接下来,关于您的问题:
If I use count sort I may decrease to O(n). If I use Count sort is it correct? Is my understanding is correct? Let me know if my understanding is wrong.
很遗憾,您的理解不正确。如果您可以在 O(1) 时间内访问要排序的每个项目的原子键,则计数排序仅是线性的。同样,这些项目是长度为 O(n) 个字符的字符串,因此这行不通。
And is there any way to find LCP in O(n) time?
是的。最近的后缀数组计算算法,包括 DC 算法(又名 Skew 算法),提供了计算 LCP 数组和后缀数组的方法,并且在 O(n) 时间内完成。
DC 算法的引用资料是 Juha Kärkkäinen, Peter Sanders: Simple linear work suffix array construction, Automata, Languages and Programming计算机科学讲义,第 2719 卷,2003 年,第 943-955 页 (DOI 10.1007/3-540-45061-0_73)。 (但这并不是允许您在线性时间内完成此操作的唯一算法。)
您可能还想看看这篇 SO 帖子中提到的开源实现:What's the current state-of-the-art suffix array construction algorithm? .除了后缀数组构造之外,那里使用的许多算法还支持线性时间 LCP 数组构造(但并非那里的所有实现实际上都可能包含该实现;我不确定)。
如果您对 Java 中的示例没问题,您可能还想查看 jSuffixArrays 的代码.除其他算法外,它还包括 DC 算法的实现以及线性时间内的 LCP 阵列构造。
关于c++ - c++后缀数组的实现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17428029/
我正在尝试创建一个包含 int[][] 项的数组 即 int version0Indexes[][4] = { {1,2,3,4}, {5,6,7,8} }; int version1Indexes[
我有一个整数数组: private int array[]; 如果我还有一个名为 add 的方法,那么以下有什么区别: public void add(int value) { array[va
当您尝试在 JavaScript 中将一个数组添加到另一个数组时,它会将其转换为一个字符串。通常,当以另一种语言执行此操作时,列表会合并。 JavaScript [1, 2] + [3, 4] = "
根据我正在阅读的教程,如果您想创建一个包含 5 列和 3 行的表格来表示这样的数据... 45 4 34 99 56 3 23 99 43 2 1 1 0 43 67 ...它说你可以使用下
我通常使用 python 编写脚本/程序,但最近开始使用 JavaScript 进行编程,并且在使用数组时遇到了一些问题。 在 python 中,当我创建一个数组并使用 for x in y 时,我得
我有一个这样的数组: temp = [ 'data1', ['data1_a','data1_b'], ['data2_a','data2_b','data2_c'] ]; // 我想使用 toStr
rent_property (table name) id fullName propertyName 1 A House Name1 2 B
这个问题在这里已经有了答案: 关闭13年前。 Possible Duplicate: In C arrays why is this true? a[5] == 5[a] array[index] 和
使用 Excel 2013。经过多年的寻找和适应,我的第一篇文章。 我正在尝试将当前 App 用户(即“John Smith”)与他的电子邮件地址“jsmith@work.com”进行匹配。 使用两个
当仅在一个边距上操作时,apply 似乎不会重新组装 3D 数组。考虑: arr 1),但对我来说仍然很奇怪,如果一个函数返回一个具有尺寸的对象,那么它们基本上会被忽略。 最佳答案 这是一个不太理
我有一个包含 GPS 坐标的 MySQL 数据库。这是我检索坐标的部分 PHP 代码; $sql = "SELECT lat, lon FROM gps_data"; $stmt=$db->query
我需要找到一种方法来执行这个操作,我有一个形状数组 [批量大小, 150, 1] 代表 batch_size 整数序列,每个序列有 150 个元素长,但在每个序列中都有很多添加的零,以使所有序列具有相
我必须通过 url 中的 json 获取文本。 层次结构如下: 对象>数组>对象>数组>对象。 我想用这段代码获取文本。但是我收到错误 :org.json.JSONException: No valu
enter code here- (void)viewDidLoad { NSMutableArray *imageViewArray= [[NSMutableArray alloc] init];
知道如何对二维字符串数组执行修剪操作,例如使用 Java 流 API 进行 3x3 并将其收集回相同维度的 3x3 数组? 重点是避免使用显式的 for 循环。 当前的解决方案只是简单地执行一个 fo
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我有来自 ASP.NET Web 服务的以下 XML 输出: 1710 1711 1712 1713
如果我有一个对象todo作为您状态的一部分,并且该对象包含数组列表,则列表内部有对象,在这些对象内部还有另一个数组listItems。如何更新数组 listItems 中 id 为“poi098”的对
我想将最大长度为 8 的 bool 数组打包成一个字节,通过网络发送它,然后将其解压回 bool 数组。已经在这里尝试了一些解决方案,但没有用。我正在使用单声道。 我制作了 BitArray,然后尝试
我们的数据库中有这个字段指示一周中的每一天的真/假标志,如下所示:'1111110' 我需要将此值转换为 boolean 数组。 为此,我编写了以下代码: char[] freqs = weekday
我是一名优秀的程序员,十分优秀!