日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

常见的js算法面试题收集,es6实现

發布時間:2023/12/6 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 常见的js算法面试题收集,es6实现 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1、js 統計一個字符串出現頻率最高的字母/數字

let str = 'asdfghjklaqwertyuiopiaia'; const strChar = str => {let string = [...str],maxValue = '',obj = {},max = 0;string.forEach(value => {obj[value] = obj[value] == undefined ? 1 : obj[value] + 1if (obj[value] > max) {max = obj[value]maxValue = value}}) return maxValue; } console.log(strChar(str)) // a 復制代碼

2、數組去重

2.1、forEach
let arr = ['1', '2', '3', '1', 'a', 'b', 'b'] const unique = arr => {let obj = {}arr.forEach(value => {obj[value] = 0})return Object.keys(obj) } console.log(unique(arr)) // ['1','2','3','a','b'] 復制代碼
2.2、filter
let arr = ['1', '2', '3', '1', 'a', 'b', 'b'] const unique = arr => {return arr.filter((ele, index, array) => {return index === array.indexOf(ele)}) } console.log(unique(arr)) // ['1','2','3','a','b'] 復制代碼
2.3、set
let arr = ['1', '2', '3', '1', 'a', 'b', 'b'] const unique = arr => {return [...new Set(arr)] } console.log(unique(arr)) // ['1','2','3','a','b'] 復制代碼
2.4、reduce
let arr = ['1', '2', '3', '1', 'a', 'b', 'b'] const unique = arr.reduce((map, item) => {map[item] = 0return map }, {}) console.log(Object.keys(unique)) // ['1','2','3','a','b'] 復制代碼

3、翻轉字符串

let str ="Hello Dog"; const reverseString = str =>{return [...str].reverse().join(""); } console.log(reverseString(str)) // goD olleH 復制代碼

4、數組中最大差值

4.1、forEach
let arr = [23, 4, 5, 2, 4, 5, 6, 6, 71, -3]; const difference = arr => {let min = arr[0],max = 0;arr.forEach(value => {if (value < min) min = valueif (value > max) max = value})return max - min ; } console.log(difference(arr)) // 74 復制代碼
4.2、max、min
let arr = [23, 4, 5, 2, 4, 5, 6, 6, 71, -3]; const difference = arr => {let max = Math.max(...arr),min = Math.min(...arr);return max - min ; } console.log(difference(arr)) // 74 復制代碼

5、不借助臨時變量,進行兩個整數的交換

5.1、數組解構
let a = 2,b = 3;[b,a] = [a,b]console.log(a,b) // 3 2 復制代碼
5.2、算術運算(加減)

輸入a = 2,b = 3,輸出 a = 3,b = 2

let a = 2,b = 3; const swop = (a, b) => {b = b - a;a = a + b;b = a - b;return [a,b]; } console.log(swop(2,3)) // [3,2] 復制代碼
5.3、邏輯運算(異或)
let a = 2,b = 3; const swop = (a, b) => {a ^= b; //x先存x和y兩者的信息b ^= a; //保持x不變,利用x異或反轉y的原始值使其等于x的原始值a ^= b; //保持y不變,利用x異或反轉y的原始值使其等于y的原始值return [a,b]; } console.log(swop(2,3)) // [3,2] 復制代碼

6、排序 (從小到大)

6.1、冒泡排序
let arr = [43, 32, 1, 5, 9, 22]; const sort = arr => {let res = []arr.forEach((v, i) => {for (let j = i + 1; j < arr.length; j++) {if (arr[i] > arr[j]) {[arr[i],arr[j]] = [arr[j],arr[i]]}}})return arr } console.log(sort(arr)) // [1, 5, 9, 22, 32, 43] 復制代碼

結語

持續更新,持續更新...

錯漏之處,敬請斧正

有更多更好的js算法面試題,還望伙伴們積極推薦

轉載于:https://juejin.im/post/5a7aaf745188257a5a4c9a39

總結

以上是生活随笔為你收集整理的常见的js算法面试题收集,es6实现的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。