我正在处理一系列子字符串问题:
给出一个字符串:
答案 0 :(得分:1)
查找包含两个唯一字符的所有子字符串的数量。
修改:我误解了这个问题。此解决方案可找到至少 2个唯一字符
的唯一子字符串 len
len * (len + 1) / 2
的给定字词的子字符串数量
sum = len * (len + 1) / 2
因此现在2个字母子串的总数为len * (len + 1) / 2 - l
。
sum = `len * (len + 1) / 2 - l`
1
和2
。
从步骤2获得的sum
中减去此当前总和。示例实现如下。
public static int allUniq2Substrings(char s[]) {
int sum = s.length * (s.length + 1) / 2 - s.length;
int sameRun = 0;
for (int i = 0, prev = -1; i < s.length; prev = s[i++]) {
if (s[i] != prev) {
sum -= sameRun * (sameRun + 1) / 2 - sameRun;
sameRun = 1;
} else {
sameRun++;
}
}
return sum - (sameRun * (sameRun + 1) / 2 - sameRun);
}
allUniq2Substrings("aaac".toCharArray());
3
allUniq2Substrings("aabc".toCharArray());
5
allUniq2Substrings("aaa".toCharArray());
0
allUniq2Substrings("abcd".toCharArray());
6
修改强> 让我再试一次。我使用上面的 3 不变量。 这是查找包含至少2个唯一字符的所有子字符串的子问题。 我在上面发布了一个方法,它为我提供了任何长度的唯一子串。我将使用它从包含2个唯一字符的集合中生成子字符串。
我们只需要跟踪设置长度为2的最长的字符串运行,即2个唯一字符的任意排列。这些运行的总和给出了所需子串的总数。
public static int allUniq2Substrings(char s[]) {
int sum = s.length * (s.length + 1) / 2 - s.length;
int sameRun = 0;
for (int i = 0, prev = -1; i < s.length; prev = s[i++]) {
if (s[i] != prev) {
sum -= sameRun * (sameRun + 1) / 2 - sameRun;
sameRun = 1;
} else {
sameRun++;
}
}
return sum - (sameRun * (sameRun + 1) / 2 - sameRun);
}
public static int uniq2substring(char s[]) {
int last = 0, secondLast = 0;
int sum = 0;
for (int i = 1; i < s.length; i++) {
if (s[i] != s[i - 1]) {
last = i;
break;
}
}
boolean OneTwo = false;
int oneTwoIdx = -1; //alternating pattern
for (int i = last + 1; i < s.length; ++i) {
if (s[secondLast] != s[i] && s[last] != s[i]) { //detected more than 2 uniq chars
sum += allUniq2Substrings(Arrays.copyOfRange(s, secondLast, i));
secondLast = last;
last = i;
if (OneTwo) {
secondLast = oneTwoIdx;
}
OneTwo = false;
} else if (s[i] != last) { //alternating pattern detected a*b*a
OneTwo = true;
oneTwoIdx = i;
}
}
return sum + allUniq2Substrings(Arrays.copyOfRange(s, secondLast, s.length));
}
uniq2substring("abaac".toCharArray())
6
uniq2substring("aab".toCharArray())
2
uniq2substring("aabb".toCharArray())
4
uniq2substring("ab".toCharArray())
1
答案 1 :(得分:0)
例如,abbaabbccd =&gt; [(0,1,),(1,2,),(3,2,T),(5,2,T),(7,2,F),(9,1) ,F)] = A
完成此示例:(从x = 0开始)
我应该提一下,你不是每次都计算从i + 1到j的总和,每次递增i时你只需减去适当的数量,只有当j增加时才重新计算它。
答案 2 :(得分:0)
我认为你发布了解决问题2的链接
http://coders-stop.blogspot.in/2012/09/directi-online-test-number-of.html
我们是否可以很容易地为第三个问题的解决方案建模。 只需在
下修改驱动程序即可int numberOfSubstrings ( string A ) {
int len = A.length();
int res = 0, j = 1, c = 1, a[2][2];
a[0][0] = A[0]; a[0][1] = 1;
for(int i=0;i<len;i++) {
>>int start = -1;
for (;j<len; j++) {
c = isInArray(a, c, A[j]);
>> if (c == 2 && start != - 1) start = j;
if(c == -1) break;
}
>>c = removeFromArray(a,A[i]);
res = (res + j - start);
}
return res;
}
关于推导的完整解释可以在链接本身中找到:)