- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
给定一个字符串和固定长度 l,我如何计算长度为 l 的不同子字符串的数量?字符集的大小也是已知的。 (记为 s)例如,给定一个字符串“PccjcjcZ”,s = 4,l = 3,然后有 5 个不同的子字符串:“PCC”; “ccj”; “cjc”; “jcj”; “jcZ”
我尝试使用哈希表,但是速度还是很慢。事实上我不知道如何使用字符大小。我做过这样的事
int diffPatterns(const string& src, int len, int setSize) {
int cnt = 0;
node* table[1 << 15];
int tableSize = 1 << 15;
for (int i = 0; i < tableSize; ++i) {
table[i] = NULL;
}
unsigned int hashValue = 0;
int end = (int)src.size() - len;
for (int i = 0; i <= end; ++i) {
hashValue = hashF(src, i, len);
if (table[hashValue] == NULL) {
table[hashValue] = new node(i);
cnt ++;
} else {
if (!compList(src, i, table[hashValue], len)) {
cnt ++;
};
}
}
for (int i = 0; i < tableSize; ++i) {
deleteList(table[i]);
}
return cnt;
}
最佳答案
Hastables 很好而且实用,但请记住,如果子字符串的长度为 L,并且整个字符串的长度为 N,则算法为 Theta((N+1-L)*L) 即 Theta( NL) 对于大多数 L。请记住,仅计算哈希值就需要 Theta(L) 时间。另外可能会发生碰撞。
可以使用后缀树,并提供一个保证O(N)时间的算法(计算深度L或更大的路径数),但实现起来比较复杂。可取之处是您可能可以找到以您选择的语言编写的现成实现。
关于c++ - 如何找到不同的子串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29516999/
例如,我有一个父类Author: class Author { String name static hasMany = [ fiction: Book,
代码如下: dojo.query(subNav.navClass).forEach(function(node, index, arr){ if(dojo.style(node, 'd
我有一个带有 Id 和姓名的学生表和一个带有 Id 和 friend Id 的 Friends 表。我想加入这两个表并找到学生的 friend 。 例如,Ashley 的 friend 是 Saman
我通过互联网浏览,但仍未找到问题的答案。应该很容易: class Parent { String name Child child } 当我有一个 child 对象时,如何获得它的 paren
我正在尝试创建一个以 Firebase 作为我的后端的社交应用。现在我正面临如何(在哪里?)找到 friend 功能的问题。 我有每个用户的邮件地址。 我可以访问用户的电话也预订。 在传统的后端中,我
我主要想澄清以下几点: 1。有人告诉我,在 iOS 5 及以下版本中,如果您使用 Game Center 设置多人游戏,则“查找 Facebook 好友”(如与好友争夺战)的功能不是内置的,因此您需要
关于redis docker镜像ENTRYPOINT脚本 docker-entrypoint.sh : #!/bin/sh set -e # first arg is `-f` or `--some-
我是一名优秀的程序员,十分优秀!