js之24道算法题

//1、冒泡排序
    var arr = [5,8,3,6,9]
    for(var i=0;i<arr.length;i++){
     for(var j=i+1;j<arr.length;j++){
          if(arr[i]>arr[j]){    
              var temp
              temp=arr[i];
              arr[i]=arr[j];
              arr[j]=temp;
              }

         }
    }
     console.log(arr)
//temp是中间变量,把要交换的第一个元素arr[j]赋值给中间变量,也是把第一个元素存储起来
//第二个元素赋值给第一个元素,因为第一个元素我们已经存储在中间变量中了,所以我们不用担心它的值会被覆盖掉
//temp存储了第一个元素的值,把它赋值给第二个元素,就是把第一个元素赋值给第二个元素了,到这一步,两个元素已经交换位置了

     //2、字符串出现最多个数(2种)
     //.str=”abcdefgaaass”找字符中出现最多的;第一种
         var str ='abcdefgaaass'
          var newarr=str.split("");
          var max=0,val="";
          function fn(arr,a){
            var count=0;
            for(var i=0;i<arr.length;i++){
                if(arr[i]==a){
                  count++;
                }
            }
            return count;
          }
          for(var i=0;i<newarr.length;i++){
              var ind=fn(newarr,newarr[i]);
              if(ind>max){
                max=ind;
                val=newarr[i];
              }
          }
          console.log("出现最多的字符是"+val+"出现的次数是"+max)
          //第二种
          var strr='aaasssssbbbcccccccccccccccccccccc'
          function change(arr){
              for(var j=0,len=0,str1='';j<arr.length;j++){
              var x = arr.substr(j,1);
              var y = arr.split(x);
              if(y.length-1>len){
                  len = y.length-1;
                  str1=x+','+len;

              }
          }
                return str1;
          }
          
          console.log(change(strr));

        
        //3、编程实现,往数组里插入一个元素
        var arr = ["1411A","44","34305","djg","pic"];
        function fun3(ar,index,date){
            for(var i=ar.length-1;i>=index;i--){
                ar[i+1]=ar[i];
            }
            ar[index] = date;
        }
        fun3(arr,2,"hello");
        console.log(arr);


        //4、编程实现IndexOf方法
        var brr=[5,9,6,3,2,5];
        function indexfun(arr,val){
            for(var i=0;i<arr.length;i++){
                if(arr[i]==val){
                    return i;
                }
            }
            return -1;
        }
        console.log(indexfun(brr,13));


        //5、求数组中最大值和最小值
        var arr=[2,41,3,1,8];
        var  temp=arr[0];

         for(var i=0;i<arr.length;i++){
               if(arr[i]<temp){
                   temp=arr[i];
               }
         }
         console.log(temp)

         

         // 6、将字符串转换为驼峰形式
        var  str="border-bottom-color";
        function isstr(str){
          var arr=str.split("-");
          var one=arr[0];
          for(var i=1;i<arr.length;i++){
              one+=arr[i].charAt(0).toUpperCase()+arr[i].substring(1);
          }
          return one;
        }
        console.log(isstr(str));
        //7、var  str='a2b4admin3'字符的每个数字都乘2 ,成为'a4b8admin6'
       var url='a2b4admin3';
       var str11=''
        for(var i=0;i<url.length;i++){
              if(!isNaN(url[i])){
                  str11=str11+url[i]*2
              }else{
                  str11=str11+url[i]
              }
        }
        console.log(str11)

        //8、var  str='a2b4admin3'将字符串中的数字用中括号括起来 'a[2]b[4]admin[3]'
      function  num(str){
      var  arr=str.split('')
      for(var i=0;i<arr.length;i++){
              if(!isNaN(arr[i])){
                  arr[i]="["+arr[i]+"]"
              }

      }
         return arr.join('')
      }

     console.log(num(url))
     //9、首先判断在数组中哪个数最大,然后让数组中的第一个数与最大的数相乘,返回结果
         function maxn(arr){
                var big=arr[0];
                for(var i=0;i<arr.length;i++){
                    if(arr[i]>big){
                        big=arr[i]
                    }
                }
                return big*arr[0]
            }
            console.log(maxn([2,1,80,6,10]));

    //10、 var str='abc' 让字符串重复3遍,成为 str='abcabcabc'
    var str='abc';
        function xun(a,b){
            var newstr='';
            for(var i=1;i<=b;i++){
                newstr+=a
            }
            return newstr
        }
        console.log(xun(str,3));

        
        //11、10到100的十位随机数并排序
        for(var i=1;i<=10;i++){            
                var ran=Math.floor(Math.random()*91+10)            
            arr.push(ran)
        }
        console.log(arr.sort(function(a,b){return a-b}))

        //12、写出一个段脚本,输出当前日期5天之后是星期几,三种方法
        //第一种
        /*var now=new Date();
        var day=now.getDate()
        var week=['日','一','二','三','四','五','六']
        now.setDate(day+5)
        console.log('星期'+week[now.getDay()])*/
        //第二种
        /*var now=new Date();
        var year=now.getFullYear();
        var month=now.getMonth();
        var date=now.getDate();
        var week=['日','一','二','三','四','五','六']
        var fulture=new Date(year,month,date+5);
        console.log('5天之后是星期'+week[fulture.getDay()])*/
        //第三种
        /*var now=new Date();
        var time=now.getTime();
        var fulture=new Date();        
        var ftime=time+24*60*60*1000*5;
        var week=['日','一','二','三','四','五','六'];    
            fulture.setTime(ftime);
        console.log('5天之后是星期'+week[fulture.getDay()])*/

        //13、封装一个n天之后是星期几的函数
        function getday(n){
            n=typeof(n)==='undefined'?0:n;
            var now=new Date();
            var time=now.getTime();
            var fulture=new Date();
            var ftime=time+24*60*60*1000*n;
            fulture.setTime(ftime);
            return fulture.getDay();
        }
        console.log(getday());

        //14、"wellcome  to beijing"把第一个变大写返回'WellcomeToBeijing'
        //和上题相同。驼峰
        

        //15、封装一个方法,实现求任意多个数的平均值。
        function f1(){
            //用一个变量接收和
            var temp = 0;
            //循环每个参数
            for(var i=0; i<arguments.length; i++){
                temp += arguments[i];
            }
            //返回平均数
            return temp/arguments.length;
        }
        console.log(f1(1,2,3,4,9))

        //16、/*判断字符串是否对称*/
        var  str1="abch6g5g6hcba";
        function isduic(str){
            for(var i=0,len=str1.length;i<len/2;i++){
              // alert(str[i]);
              if(str[i]!=str[len-1-i]){//str.charAt(i)!=str.charAt(len-1-i);
                  return "不对称";
              }
            }
            return "对称";
        }
        console.log(isduic(str1));

        //17、千分符
         var str2=46548978911;
        function qianff(str){
            var strn=str.toString(),
                len=strn.length,
                ind=len%3,
                //console.log(strn)
                newstr=strn.substr(0,ind);
                console.log(newstr);
                if(ind==0){
                   newstr=strn.substr(0,3);
                    ind=3;
                    //console.log(newstr);
                }
                for(i=ind;i<len;i=i+3){
                  newstr+=","+strn.substr(i,3);
                }
                return newstr;
        }
        console.log(qianff(str2))

        //18、随机生成十六进制的颜色值 var arr=["0","2","3","4","5","6","7","8","9","a","b","c","d"]
        var arrHex=["0","2","3","4","5","6","7","8","9","a","b","c","d"];
        var fuhao = "#";
        for(var i=0;i<6;i++){
            var color = arrHex[Math.floor(Math.random()*arrHex.length)];
            fuhao= fuhao+color;
            // str =str+arrHex[a];
        }
        console.log(fuhao);

        //19、随机从数组中取出三个不同的值。var arr = [1,2,3,4,5,6,7,8,9];
        var arr = [1,2,3,4,5,6,7,8,9];
        console.log(arr.indexOf(0))

        // var brr = [];
        // for(var i=0;brr.length<3;i++){
        //     var a = Math.floor(Math.random()*arr.length);
        //     var b = arr[a];
        //     if(brr.indexOf(b)==-1){//
        //         brr.push(b);                                                                                    }
        // }
        // console.log(brr);

        //20、求数组中字符串的个数
        var str=[0,1,2,3,4,5,"a","b","c","b"],sum=0;
        function strn(arr){
            for(var i=0;i<arr.length;i++){
                if(typeof(arr[i])=="string"){
                    sum++;
                }
            }
            return sum;
        }
        console.log(strn(str));

        //21、删除数组中指定的值
        var drr = ["1411A","44","34305","djg","pic",100,35,28];
        function fun5(rr,num){
            // for(var i = 0; i<rr.length;i++){
            //     if(rr[i]==num){
            //         rr.splice(i,1);
            //         break;
            //     }
            // }
            var newrr = rr.splice(num,1);
            return rr;            
        }
        console.log(fun5(drr,1));

        //22、把重复的值放入一个新的数组中  //这中方法过于繁琐,可以使用indexOf方法,等于-1判断
        var str = ["55","55","2","1"];
        function fen(arr,num){
            var a = 0;
            for(var i = 0;i<arr.length;i++){
                if(arr[i]==num){
                    a++;
                }
            }
            return a;
        }
        var xin = [];
        for(var i = 0 ;i <str.length;i++){
            var length = fen(str,str[i]);
            if(length >1){
                xin.push(str[i]);
            }
        }
        console.log(xin);

        //23、截取字符串的var s="abcdefg";截取完成后实现反转功能:g,f,e  其实等同于数组翻转
            // 第一种
        /*var str="hello";
        var arr=str.split("");
        var rts=arr.reverse();
        console.log(rts);*/
        // 第二种
        /*var str="hello";
        var strn="";
        for(var i=str.length;i>=0;i--){
            strn+=str[i];
        }
        console.log(strn);*/
        //第三种
        /*var str="hello",arr=[];
        for(var i=0;i<str.length;i++){
            arr.unshift(str[i]);
        }
        console.log(arr);*/

        //24、拓展一个方法,用于删除数组中的指定值。同21题一样


        //附1:编程实现数组中有几个字符串元素
        var brr = ["1411A","44","34305","djg","pic",100,35,28];
        function fun4(crr){
            var count = 0;
            for(var i = 0;i<crr.length;i++){
                if(typeof crr[i] == "string"){
                    count++
                }
            }
            return count;
        }
        fun4(brr);
        
        
        //附2:数组反转
        var s = "abcdefghiklmn";
        function fun6(str){
            // var ss = s.splice("");
            var ss = s.split("");
            var ssa = [];
            for(var i = 0 ;i<ss.length;i++){
                ssa.unshift(ss[i]);
            }
            return ssa.join("");
        }
        fun6(s);
        //附3:将所有数组内所有重复的值取出来放到一个新的数组中
      // var st="123abcdefgaaaasssssssssssssss123",srn="",cou=0;
      // var str=st.split("");
      // function stn(srr,strn){
      //     var count=0;
      //     for(var i=0;i<srr.length;i++){    
      //         if(srr[i]==strn){
      //             count++;
      //         }
      //     }
      //     return count;
      // }            
      // for(var i=0;i<str.length;i++){
      //     var anr=stn(str,str[i]);
      //     if(anr>cou){
      //         cou=anr;
      //         srn=str[i];
      //     }
      // }  
      // console.log("出现最多的字母是"+srn+"次数"+cou); 
      

//函数变量作用域问题
     // var tt = 10;
        // function fun1(){
        //     alert(tt);
        //     var tt = 20;
        //     alert(tt);
        // }
        // fun1();
        // var a = 5;
        // function fun2(a){
        //     a = 10;
        //     alert(a);
        // }
        // fun2(a);

 

posted @ 2020-07-09 17:14  我自是年少  阅读(545)  评论(0编辑  收藏  举报