我写了一个代码,它工作得很好,但是有没有任何简单和更方便的方法来使用 javascript RegExp 对象或任何其他方式来实现它?
function removeDuplicateChar(str) {
var temp = [], j = 0;
var arr = str.split("");
arr.sort();
for(var i = 0; i < arr.length-1; i++) {
if(arr[i] != arr[i+1]) {
temp[j++] = arr[i];
}
}
temp[j++] = arr[arr.length-1];
for(var i = 0; i < j; i++) {
arr[i] = temp[i];
}
return arr.join("").substring(0,j);
}
console.log(removeDuplicateChar("Rasikawef dfv dd"));
您喜欢单衬吗?最少的代码可以非常高效。比较以下内容:
使用集合和列表理解:
const remDup= e => [...new Set(e)].sort().join("");
console.log(remDup("Rasikawef dfv dd"))
减少:
const remDup= s=> s.split("").sort().reduce((a,b)=>(a[a.length-1]!=b)?(a+b):a,"")
console.log(remDup("Rasikawef dfv dd"))
带过滤器:
const remDup= s=> s.split("").filter((e,i,f)=>f.indexOf(e)==i).sort().join("")
console.log(remDup("Rasikawef dfv dd"))
附地图:
const remDup= s=> s.split("").map((c,i,o)=>(o.indexOf(c)==i)?c:"").sort().join("")
console.log(remDup("Rasikawef dfv dd"))
let removeDuplicate = (string) => string.split("").reduce((s, c) => {
if (s) {
if (-1 == s.indexOf(c)) return s + c;
}
return s;
});
console.log(removeDuplicate("banana")); // => ban
console.log(removeDuplicate("Rasikawef dfv dd")); // => Rasikwef dv
function dupRemove(stringValue) {
let updatedValue = "";
for (i = 0; i < stringValue.length; i++) {
if (updatedValue.indexOf(stringValue[i]) == -1) {
updatedValue = updatedValue + stringValue[i]
}
}
return updatedValue;
}
console.log(dupRemove("apple")); // "aple"