請給Array本地對象增加一個原型方法,它的用途是刪除數(shù)組條目中重復(fù)的條目(可能有多個),返回值是一個僅包含被刪除的重復(fù)條目的新數(shù)組。
var hashCode = function(element){
return element.sort().toSource();
}
Array.prototype.dell = function(hashCode){
var deleList = [];
var obj = {};
do {
var ele = this.pop();
var key = hashCode(ele);
if (obj[key]) {
deleList.push(ele);
}
else {
obj[key] = ele;
}
}
while (this.length > 0);
for (var key in obj) {
this.push(obj[key]);
}
return deleList;
}
var list = [[3, 1], [1, 2], [1, 3]]
expect([[1, 3]]).to(equal, list.dell(hashCode));
expect([[1, 2], [1, 3]].sort()).to(equal, list.sort());
已有 0 人發(fā)表留言,猛擊->>這里<<-參與討論
JavaEye推薦
文章來源:
http://sevenduan.javaeye.com/blog/506830