1.給出一個字符串,顯示出字符串裏重複次數最多的元素,並顯示次數出來javascript
如:"sdoiokasdhdiuwasad" java
輸出: 出現最多:d 出現次數:4node
1 function remenber(str){ 2 var o = {}; 3 for (var i = 0; i < str.length; i++) { 4 if (o[str[i]]) { //char就是對象o的一個屬性,o[char]是屬性值,o[char]控制出現的次數 5 o[str[i]]++; //次數加1 6 } else { 7 o[str[i]] = 1; //若第一次出現,次數記爲1 8 } 9 } 10 console.log(o); //輸出的是完整的對象,記錄着每個字符及其出現的次數 11 //遍歷對象,找到出現次數最多的字符和次數 12 var max = 0; 13 for (var key in o) { 14 if (max < o[key]) { 15 max = o[key]; //max始終儲存次數最大的那個 16 } 17 } 18 for (var key in o){ 19 if (o[key] == max){ 20 //console.log(key); 21 console.log("最多的字符是" + key); 22 console.log("出現的次數是" + max); 23 } 24 } 25 } 26 remenber("sdoiokasdhdiuwasad");
2.給出一個數組,數組中的元素最多能夠出現兩次git
1 function newarr(arr){ 2 var tmp = []; 3 var str = ","; 4 for(var i = 0; i < arr.length; i++){ 5 var sm = str.match(new RegExp(","+arr[i]+",", "g")); 6 if(!sm || sm.length < 2) { 7 tmp.push(arr[i]); 8 str += arr[i] + ","; 9 } 10 } 11 console.log("原數組是:" + arr); 12 console.log("清除後的數組:"+tmp); 13 } 14 newarr([12,34,5,6,32,12,34,56,5,12,34]);
3.給出一個數組,求這個數組的最大和github
如[34,5,1,22],輸出534221算法
function a(arr){ var st = []; var res = []; for(var i=0; i < arr.length; i++){ //將數組元素轉換爲string類型 var arr1 = arr[i].toString(); st.push(arr1); } console.log(st[1][0]); for(var j = 0; j < arr.length-1; j++){ //用冒泡排序將數組的元素的第一個數進行排序的到從小到大的排序 for(var k = 0; k < arr.length-j-1; k++){ if(st[j][0] > st[j+1][0]){ var temp = st[k]; st[k] = st[k+1]; st[k+1] = temp; } } } for(var c = st.length; c >= 0; c--){//將冒泡排完序後的到的數組進行倒序排序 res.push(st[c]); } console.log(res.join(""));//最後合併元素 } a([12,23,34,5]);
四、給一個有序數組建立二叉搜索樹數組
var Array = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]; var Tree = createTree(Array); console.log(Tree); // 構造一個節點 function Node(nodeData, leftData, rightData) { this.nodeData = nodeData; this.leftData = leftData; this.rightData = rightData; } // 每次取中點做爲根節點,向左和向右遞歸 function createTree(array) { if (array.length <= 0) { return null; } else { var mid = parseInt(array.length / 2); var node = new Node(array[mid], null, null); var leftArray = array.slice(0 , mid); var rightArray = array.slice(mid + 1 , array.length ); node.leftData = createTree(leftArray); node.rightData = createTree(rightArray); return node; } }
五、JS快速排序dom
function quicksort(arr){ if(arr.length <= 1){ return arr; } var mid = Math.floor(arr.length/2); //用於肯定中間基數在arr中的位置 var andtwo = arr.splice(mid,1)[0]; //用於做鏈接left和right兩個數組的中間基數 var left = []; var right = []; for(var i = 0; i < arr.length; i++){ if(arr[i] > andtwo){ right.push(arr[i]); }else{ left.push(arr[i]); } } return quicksort(left).concat([andtwo],quicksort(right)); } console.log(quicksort([12,4,43,16,34,76,8,97]));
六、給一個字符串如as-ds-aw-gfde-ioa,用一個函數實現輸出結果爲as-Ds-Aw-Gfde-Ioa函數
function toUp(str){ var mixstr = str.split("-");//將str拆分 var res = [mixstr[0]];//建立新數組用於存放轉換好的元素,由於第一個不須要轉換,因此直接存放進去了 for(var i = 1; i < mixstr.length; i++){ var resone = mixstr[i][0].toUpperCase() + mixstr[i].substring(1,mixstr[i].length);//將str裏的單個字符串轉換成首字母爲大寫的形式 res.push(resone); } var outstr = res.join("-"); console.log(outstr); } toUp("as-ds-aw-gfde-ioa");
七、實現一個算法,隨機生成指制定長度的字符竄。ui
好比給定 長度 8 輸出 2debl8xp
function randomString(n) { let str = 'abcdefghijklmnopqrstuvwxyz9876543210'; let tmp = ''; for (var i = 0; i < n; i++) { tmp += str.charAt(Math.floor(Math.random() * str.length)); } console.log(tmp); } randomString(8);