这是Codewars中的挑战之一,我应该编写一个函数,它将获取一个字符串并返回一个数组,其中我不能有两个连续的相同元素。此外,订单不应更改。
例如,如果我传递字符串"hhhhheeeelllloooooohhheeeyyy"
,则该函数应返回array = ["h","e","l","o","h","e","y"]
。
这是我的代码。
var uniqueInOrder=function(iterable){
//your code here - remember iterable can be a string or an array
var unique = [];
for( var i = 0; i < iterable.length; i++) {
unique.push(iterable[i]);
}
for( var j = 0, k = 1; j < unique.length; j++, k = j + 1 ){
if(unique[j] === unique[k]){
unique.splice(k,1);
}
}
return unique;
}
所以,如果我传递一个字符串,例如"hhhhheeeeeellllloooo"
,它就不会像我想要的那样工作,因为j
的值不断递增,因此我无法做到过滤掉所有相同的元素。
我尝试调整逻辑,这样每当unique[j] === unique[k]
j的值变为零时,如果情况不是这样,那么事情就会继续进行。
这让我无限循环。
我需要你的帮助。
答案 0 :(得分:1)
您只需将当前可迭代索引与唯一中的最后一个字符进行比较:
function(iterable){
var unique = []
for(var i=0; i< iterable.length; i++){
if(unique.length < 1){
unique.push(iterable[i])
} else if(iterable[i] !== unique[unique.length - 1]) {
unique.push(iterable[i])
}
}
return unique
}
答案 1 :(得分:1)
第二个for loop
失败,因为unique.length
在运行期间不是常量。
我认为你的问题可以这样解决:
var temp = iterable[0];
unique.push(iterable[0]);
for( var i = 1; i < iterable.length; i++) {
if(iterable[i] != temp) {
unique.push(iterable[i]);
temp = iterable[i];
}
}
希望它有所帮助!
答案 2 :(得分:0)
我认为这会对你有所帮助:
var word="hhhhheeeelllloooooohhheeeyyy"
function doit(iterable){
var unique = []
unique[0]=iterable[0]
for(var i=1; i< iterable.length; i++){
if(iterable[i] !== unique[unique.length - 1]) {
unique.push(iterable[i])
}
}
return unique
}
alert(doit(word))
for循环不会失败,因为unique.length是动态的,即随着新元素添加到数组而改变。
也在Internet Explorer中测试过。 以下是jsfiddle的链接:https://jsfiddle.net/kannanore/z5gbee55/
答案 3 :(得分:0)
var str = "hhhhheeeelllloooooohhheeeyyy";
var strLen = str.length;
var newStr = "";
for(var i=0; i < strLen; i++ ){
var chr$ = str.charAt(i);
//if(i==0) {newStr = chr$ };
if(chr$ == str.charAt(i+1)){
strLen = str.length;`enter code here`
}else{
newStr = newStr + chr$ ;
}
}
//document.write(newStr);
console.log(newStr);
//Answer: helohey