var a = 'lkjgfaoids’; var b = 'adk’;
问题: 判断出字符串 b 中的每一个字符,在 a 中是否存在。
这是一个性能优化题,下面的解法性能不够,请提出更好的方案。
解法一:
var as = a.split(‘’);
var bs = b.split(‘’);
for(var i in as){
for(var k in bs){ if(as[i]==bs[k]){ … } } }
解法二:
var bs = b.split(‘’); for(var i in bs){ if(a.indexOf(bs[i])){ … } }
这样呢?
b.split('').forEach(function(item){
if(a.localeCompare(item)){
console.log('%s exits', item);
}
});
var map_arr = [] for(var i=0;i<a.length;++i) map_arr[a[i]]=1 for(var i=0;i<b.length;++i) if(map_arr[b[i]]) return true return false 随便写了伪代码,求工作介绍
@leapon 恩恩 把return逻辑颠倒一下就行
var map_arr = [] for(var i=0;i<a.length;++i) map_arr[a[i]]=1 for(var i=0;i<b.length;++i) if(!map_arr[b[i]]) return false return true
@alsotang 例如var a = '112233’; a = a.replace( /1/, ‘’ );a现在为’2233’,长度发生了变化,就知道1在a中出现过了。我也是给出一种思路,具体性能没测试过,这个题目其实根据a和b的长度的不同方法也可能不一样,我提出的这个比较适合a很长,b在a中出现次数比较多,还可以统计出次数。
var a = 'lkjgfaoids’; var b = 'adk’;
问题: 判断出字符串 b 中的每一个字符,在 a 中是否存在。 解法:
var bs = b.split(‘’);
if(a.indexOf(bs[0])){ … }
if(a.indexOf(bs[1])){ … }
if(a.indexOf(bs[2])){ … }
只有三个字母,所以不用循环。还请大家指教。
var str = 'lkjgfaoids’; var reg = /[adk]/g; var result = reg.exec(str); if(result.length === 3) { return true; }
没测试过性能 var a = 'lkjgfaoids’; var b = 'adk’; var aa = a.split(‘’).sort().join(‘’); var bb = b.split(‘’).sort(); var reg = new RegExp(bb.join(‘.*’)); console.log(reg.test(aa));
var a = 'lkjgfaoids’; var b = 'adk’; for(var i = 0, len = b.length; i < len; i++) { a.indexOf(b.charAt(i)) > -1 && console.log(b.charAt(i)); }
虽然有点长,但是题中的应该是够用的 var findChar = (function() { if(typeof Array.prototype.forEach !== “function”) { Array.prototype.forEach = function(callback, thisArgs) { if(typeof callback !== “function”) { throw new TypeError(‘type error’); } var len = this.length, _this = thisArgs || window; for(var i =0; i < len; i++) { callback.call(_this, this[i], i, this); } } } function find(ori, des) { var desArr = []; //slice方法 for (var i = 0,j = des.length; i < j; i++) { desArr.push(des.charAt(i)); } desArr.forEach(function(val) { if(ori.indexOf(val) > -1) { //… } }) } return find; })(); findChar('lkjgfaoids’, ‘adk’);