leetcode 703 数据流中的第K大元素(javascript)

var KthLargest = function(k, nums) {
    this.k = k
    this.arr = []
    for(let i=0;i<nums.length;i++){
        this.add(nums[i])
    }
};

KthLargest.prototype.add = function(val) {
     let sign = true  
     if(!this.arr.length) {
         this.arr.push(val)
     } else {
         let i = 0
         while(i<this.arr.length){
             if(val<this.arr[i]){
                 this.arr.splice(i,0,val)
                 sign = false
                 break
             }
         }

         if(sign){
             this.arr.push(val)
         }

         if(this.arr.length>this.k){
             this.arr.shift()
         }
      
     }
     return this.arr[0]
};

快排超时!

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