您好,登錄后才能下訂單哦!
這篇文章主要介紹面試常見的js算法題有哪些,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
1.排序
一般都是給個數組然后排序,有的從小到大,有的從大到小。一定要看清楚。以下都是從小到大的排序算法。
冒泡法
var arr = [3,6,1,2,5]; var temp; for(var i= 0;i<arr.length;i++){ for(var j=i+1;j<arr.length;j++){ if(arr[i] > arr[j]){ temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; } } } console.log(arr);
快速排序法
function quicksort (arr){ if(arr.length<=1){ return arr; } var left = []; var right = []; var middle = arr[0]; for(var i=1;i<arr.length;i++){ if(arr[i]<middle){ left.push(arr[i]); }else{ right.push(arr[i]); } } return quicksort(left).concat([middle],quicksort(right)); }
注意:可以用快速就不要用冒泡。實在沒記住才用冒泡。(因為快速排序設計到遞歸,面試官更多是想考察你遞歸算法)
2.數組去重
這題考察的是你會不會存儲數組元素的出現次數來解決去重問題。當然解法也有很多,下面是其中一種解法。
Array.prototype.unique = function(){ var res = []; var json = {}; for(var i = 0; i < this.length; i++){ if(!json[this[i]]){ res.push(this[i]); json[this[i]] = 1; } } return res; } var arr = [112,112,34,'你好',112,112,34,'你好','str','str1']; alert(arr.unique());
3.js的拷貝
這題涉及到的就是你能不能清楚的分辨深拷貝和淺拷貝。
var a = {name:'Tom'}; var b = a; b.name = 'Peter';
請問a.name = ?
正確答案是Peter,如果你的答案是Tom的話,那么你要好好去看看js的深拷貝。
如果要被拷貝的是數組:
slice和concat都可以直接讓數組進行深拷貝
arr.slice(); arr.concat();
下面是解法。當然肯定有比我寫得更好的。
function deepCopy(source){ var result = {}; for(var i in source){ if(typeof source[i] === "object"){ result[i] = deepCopy(source[i]); }else{ result[i] = source[i]; } } return result; }
4.獲取字符串里出現子串的位置
function appear(str,str_target){ var n = 0; var result = []; while(str.indexOf(str_target,n)!=-1 && n < str.length){ result.push(str.indexOf(str_target,n)); n = str.indexOf(str_target,n) + str_target.length; } return result; } var arr = appear('abascbascbabasbascbascascbab','ab'); console.log(arr);
5.不確定數量的數組遍歷組合算法
好吧,解釋下這題。這題在現實中確實會用到。尤其是做商城網站時,sku的算法真的經常會遇到。
這題的意思就是說。相當于說[1,2,3],[4,5]。。。。的不確定個數的數組進行遍歷組合,組成[[1,4],[1,5],[2,4],[2,5],[3,4],[3,5]]這樣。然后數組越多,組出來就肯定越多。
那怎么做的,我上網查了一些相關算法都沒找到好的,然后我就自己寫。可能還是會有點毛病,大家將就看。
有寫的更好的歡迎評論教我一下。
function group(arr,re){ if(arr.length <=0){ return re; } if(!re){ var arr = arr.slice(); var re = arr.shift(); return group(arr,re); }else{ var now = arr.shift(); var newre = []; for(var j=0;j<now.length;j++){ for(var k=0;k<re.length;k++){ var temp = []; if(re[k] instanceof Array){ temp = re[k]; }else{ temp.push(re[k]); } newre.push(temp.concat(now[j])); } } return group(arr,newre); } } var arr = [['a','b','c'],['e','d','f'],['h','i'],['j','k','l','m']]; // var arr = [['a','b','c'],['e','d','f'],['h','i']]; // console.log(arr); var result = group(arr); console.log(result);
6.lazyMan(這道題考察了很多內容)
這道題自行百度吧。。只要百度lazyMan 面試題,應該是可以搜出來的
7.編寫一個函數fn(Number n),將數字轉為大寫輸出,如輸入123,輸出一百二十三。
好吧,這道題我是忘了我看的本站的哪位的文章了,覺得確實有點意思。
下面是他的代碼。
function fn(n){ if(!/^([1-9]\d*)/.test(n)){ return '非法數據'; } var unit = '千百十億千百十萬千百十個'; if(n.length > unit.length){ return '數據過長'; } var newStr = ''; var nlength = n.length; unit = unit.substr(unit.length - nlength); for(var i = 0; i < nlength; i++){ newStr += '零一二三四五六七八九'.charAt(n[i]) + unit.charAt(i); } newStr = newStr.substr(0,newStr.length-1); newStr = newStr.replace(/零(千|百|十)/g,'零').replace(/(零)+/g,'零').replace(/零(億|萬)/g,'$1'); return newStr; } console.log(fn('205402002103'));
8.如何將浮點數左邊的數每三位添加逗號
如1200000.11轉成12,000,000.11
result = num && num.toString().replace(/(\d)(?=(\d{3})+\.)/g,function($1,$2){ return $2 + ','; })
上面的解法是用正則,當然你也可以用別的方法。
以上就是面試常見題目。可能會有遺漏。歡迎補充。
不要光看。。要自己動手寫一下,不然你以為你看會了。其實要你寫,你還是寫不出。
ok. 就這樣。
以上是“面試常見的js算法題有哪些”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。