最近前端筆試趕上的筆試題有感

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

相關文章
相關標籤/搜索