function countZero(n){ var count = 0; while(n>0){ count += Math.floor(n/10); n = n/10; } return count; } countZero(2014); // = 223
子字符串
Q: 在字符串中匹配子字符串?
A: 在迭代字符串时将使用指针(一个用于字符串,另一个用于子字符串)。 然后用另一个变量来保存初始匹配的起始索引。
function subStringFinder(str, subStr){ var idx = 0, i = 0, j = 0, len = str.length, subLen = subStr.length; for(; i<len; i++){ if(str[i] == subStr[j]) j++; else j = 0; //check starting point or a match if(j == 0) idx = i; else if (j == subLen) return idx; } return -1; } subStringFinder('abbcdabbbbbck', 'ab') // = 0 subStringFinder('abbcdabbbbbck', 'bck') // = 9 //doesn't work for this one. subStringFinder('abbcdabbbbbck', 'bbbck') // = -1
排列
Q: 如何获取字符串中的所有排列?
A: 根据您对算法的了解程度,这可能会很困难。、
function permutations(str){ var arr = str.split(''), len = arr.length, perms = [], rest, picked, restPerms, next; if (len == 0) return [str]; for (var i=0; i<len; i++) { rest = Object.create(arr); picked = rest.splice(i, 1); restPerms = permutations(rest.join('')); for (var j=0, jLen = restPerms.length; j< jLen; j++) { next = picked.concat(restPerms[j]); perms.push(next.join('')); } } return perms; }
总结
以上所述是小编给大家介绍的Js面试算法详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对黑区网络网站的支持!