如何确定一个字符串是否包含重复字母序列

12

使用JavaScript,我需要检查给定的字符串是否包含重复字母序列,例如:

"aaaaa"

我该如何实现这个功能?


1
你需要考虑像双L或双C这样的重复有效情况吗? - Dimitri
是的,所有字母重复超过一次的地方。 - vetri02
2
你想知道的只是是否存在吗?还是你想知道它们是什么? - Eric
7个回答

15
你可以使用这个函数:
function hasRepeatedLetters(str) {
    var patt = /^([a-z])\1+$/;
    var result = patt.test(str);
    return result;
}

2
因为如果我运行它,它会出错。 - Eric
如果字符串中只是重复相同的字符,例如 "aaaaaaaaaaaa" 而不是 "aadaa",应该怎么办? - vetri02
@weblearner 两者都会返回 true。你想让它有不同的行为吗? - melhosseiny
是的,它应该只在整个字符串中只有一个字符重复时才匹配。 - vetri02

13

使用正则表达式:

var hasDuplicates = (/([a-z])\1/i).test(str)

或者,如果你不想匹配 aA 等类似的字符

var hasDuplicates = (/([a-zA-Z])\1/).test(str)

或者,如果你已经决定要澄清你的问题:

var hasDuplicates = (/^([a-zA-Z])\1+$/).test(str)

3

尝试使用这个

checkRepeat = function (str) {
    var repeats = /(.)\1/;
    return repeats.test(str)
}

示例用法

if(checkRepeat ("aaaaaaaa"))
alert('Has Repeat!')

3

这将检查字符串是否重复超过两次:

function checkStr(str) {
    str = str.replace(/\s+/g,"_");
    return /(\S)(\1{2,})/g.test(str);
}

只是想问一下,如果我想把你的表达式作为变量使用,比如像这样:const repeatRegex = new RegExp(/(\S)(\1{2,})/g) ?? 我遇到了八进制错误。 - jlc488

2
function check(str) {
    var tmp = {};
    for(var i = str.length-1; i >= 0; i--) {
        var c = str.charAt(i);
        if(c in tmp) {
            tmp[c] += 1;
        }
        else {
            tmp[c] = 1;
        }
    }
    var result = {};
    for(c in tmp) {
        if(tmp.hasOwnProperty(c)) {
            if(tmp[c] > 1){
                result[c] = tmp[c];
            }
        }
    }
    return result;
}

然后您可以检查结果以获取重复字符及其频率。如果结果为空,则没有重复。


1
请注意,在一些旧的浏览器上,不支持对字符串使用[]符号表示法;在这种情况下,请使用c = str.charAt(i)而不是c = str[i] - T.J. Crowder

2

我使用了一个for循环,而不是正则表达式来解决这个问题。

//This check if a string has 3 repeated letters, if yes return true, instead return false
//If you want more than 3 to check just add another validation in the if check

function stringCheck (string) {
    for (var i = 0; i < string.length; i++)
        if (string[i]===string[i+1] && string[i+1]===string[i+2]) 
            return true
    
    return false  
}
var str1 = "hello word" //expected false
var str2 = "helllo word" //expredted true
var str3 = "123 blAAbA" //exprected false
var str4 = "hahaha haaa" //exprected true

console.log(str1, "<==", stringCheck(str1))
console.log(str2, "<==", stringCheck(str2))
console.log(str3, "<==", stringCheck(str3))
console.log(str4, "<==", stringCheck(str4))


0
var char = "abcbdf..,,ddd,,,d,,,";
var tempArry={};

for (var i=0; i < char.length; i++) {
    if (tempArry[char[i]]) {
        tempArry[char[i]].push(char[i]);
    } else {
        tempArry[char[i]] = [];
        tempArry[char[i]].push(char[i]);
    }
}

console.log(tempArry);

这将甚至返回重复字符的数量。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接