function difference(a, b) {
a = a.split(' ');
b = b.split(' ');
var d1 = a.filter(function(i) {return !(b.indexOf(i) > -1);});
var d2 = b.filter(function(i) {return !(a.indexOf(i) > -1);});
return d1.concat(d2);
}
alert(difference("Мама мыла очень кривую раму", "Мама долго мыла кривую раму"));
|
Началось, кто короче) Я только-только 1-й вариант прожевал)
Спасибо :) Вы не подскажете, как знаки препинания тоже в отдельные элементы массива положить? Потому что иначе с ними тоже косяк. С регулярками, увы, не дружу совсем. :( |
function difference(a, b) {
var re = /([~!$%^&*()_+|`\-=\\\[\]{};':",\.\/<>?@#])/g;
a = a.replace(re, ' $1').split(' ');
b = b.replace(re, ' $1').split(' ');
var d1 = a.filter(function(i) {return !(b.indexOf(i) > -1);});
var d2 = b.filter(function(i) {return !(a.indexOf(i) > -1);});
return d1.concat(d2);
}
alert(difference("Мама! мыла очень кривую раму", "Мама? долго мыла кривую раму"));
|
devote,
Спасибо большое! |
tsigel,
Обратите внимание indexOf и filter не доступны в IE до IE9. |
вот полифил filter:
if (!Array.prototype.filter) {
Array.prototype.filter = function(fun /*, thisp*/) {
'use strict';
if (!this) {
throw new TypeError();
}
var objects = Object(this);
var len = objects.length >>> 0;
if (typeof fun !== 'function') {
throw new TypeError();
}
var res = [];
var thisp = arguments[1];
for (var i in objects) {
if (objects.hasOwnProperty(i)) {
if (fun.call(thisp, objects[i], i, objects)) {
res.push(objects[i]);
}
}
}
return res;
};
}
И соответственно indexOf:
if (!Array.prototype.indexOf) {
Array.prototype.indexOf = function (searchElement /*, fromIndex */ ) {
'use strict';
if (this == null) {
throw new TypeError();
}
var n, k, t = Object(this),
len = t.length >>> 0;
if (len === 0) {
return -1;
}
n = 0;
if (arguments.length > 1) {
n = Number(arguments[1]);
if (n != n) { // shortcut for verifying if it's NaN
n = 0;
} else if (n != 0 && n != Infinity && n != -Infinity) {
n = (n > 0 || -1) * Math.floor(Math.abs(n));
}
}
if (n >= len) {
return -1;
}
for (k = n >= 0 ? n : Math.max(len - Math.abs(n), 0); k < len; k++) {
if (k in t && t[k] === searchElement) {
return k;
}
}
return -1;
};
}
|
Цитата:
|
оффтоп: winmerge изобретаем, понятно...
|
| Часовой пояс GMT +3, время: 00:33. |