7月13 直播课笔试题

字符串反转

function reverse1(input){
  if(typeof input !== 'string'){
      throw new Error('给我字符串啊')
  }
  var output = ''
  for(var i = 0; i< input.length; i++){
    output =  input[i] + output
  }
  return output
}
function reverse2(input){
   if(typeof input !== 'string'){    throw new Error('我只要字符串') }
   return input.split('').reverse().join('')
}

var t1= new Date()
for(var i =0;i<100000;i++){
    reverse1('sakjdlaskjdlaskjdaslkjdaslkjdaslkfjaslkfjaslf;kj')
}
console.log(new Date() - t1)

var t2= new Date()
for(var i =0;i<100000;i++){
    reverse2('sakjdlaskjdlaskjdaslkjdaslkjdaslkfjaslkfjaslf;kj')
}
console.log(new Date() - t2)

加横线
输入‘12346789’
输出‘123-456-789’

function x(input){
  var output = ''
  for(var i =0; i<input.length; i++){
    output = output  + input[i]
    if( i % 3 === 2 && i !== input.length - 1){
      output = output + '-'
    }
  }
  return output
}

反方向加-

function xx(input){
  var output = ''
  for(var i = input.length-1; i>=0; i--){

    output = input[i] + output
    if((input.length - i) % 3 === 0 && i !== 0){
      output = '-' + output
    }
  }
  return output
}
clear()
console.log(xx('123456789'))
console.log(xx('12345678'))

去重
输入[1,2,3,3,4,4,4]
输出[1,2,3,4]
输入[1,2,'2','3',3,3,4,4,4]
输出[1,2,3,4]
排序方法
1.冒泡
2选择
3插入
4快速
5堆排序
6桶排序
7归并
8基数

function unique(array){
    var newArray = []
    for(var i=0; i<array.length; i++){
        var exist = inArray(newArray, array[i]) // array[i] 是否已经在 newArray 里面
        if(!exist){
            newArray.push(array[i])
        }
    }
    function inArray(a, n){
        var bool = false
        for(var i=0; i<a.length; i++){
            if(a[i] === n){
                bool = true
            }
        }
        return bool
    }
    return newArray
}
//利用桶排序和对象,但不能完成第二种
function unique(array){
    var newArray = []
    var hash = {}
    for(var i =0; i<array.length; i++){
        var number = array[i]
        if(number in hash){

        }else{
            hash[number] = '方方'
        }
    }
    for(var key in hash){
        newArray.push(key)
    }

    return newArray
}
clear()
console.log(unique([1,2,2,2,2,2,3,3,3,4,4,244,255,244]))
// 对象中key都是字符串。
//mdn set

//underscore库/loadsh 引入window._

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 9.3.3 快速排序   快速排序将原数组划分为两个子数组,第一个子数组中元素小于等于某个边界值,第二个子数组中的...
    RichardJieChen阅读 1,870评论 0 3
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,222评论 0 52
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 3,747评论 0 15
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 1,286评论 0 2
  • 1.简介 数据存储有哪些方式?电子表格,纸质文件,数据库。 那么究竟什么是关系型数据库? 目前对数据库的分类主要是...
    乔震阅读 1,786评论 0 2