zoukankan      html  css  js  c++  java
  • leetcode 1046

    class Solution {
       
        public int lastStoneWeight(int[] stones) {
            MaxHeap s=new MaxHeap(stones.length+1);
            for(int i=0;i<stones.length;i++)
            {
                s.insert(stones[i]);
            }
            while(s.size()>1)
            {
                int y=s.extractMax();
                int x=s.extractMax();
                if(y>x)
                {
                    s.insert(y-x);
                }
            }
            if(s.size()==1)
            {
                return s.extractMax();
            }
            else
                return 0;
            
        }
    }
    class MaxHeap{
        private int[] stone;
        private int count;
        private int capacity;
        public MaxHeap(int capacity)
        {
            this.capacity=capacity;
            stone=new int[capacity+1];
            count=0;
        }
        public void insert(int n)
        {
            stone[++count]=n;
            shiftUp(count);
        }
        private void shiftUp(int count)
        {
            while(count>1&&stone[count/2]<stone[count])
            {
                swap(count/2,count);
                count=count/2;
            }
        }
        public void swap(int i,int j)
        {
            int temp=stone[i];
            stone[i]=stone[j];
            stone[j]=temp;
        }
        public int extractMax()
        {
            int res=stone[1];
            swap(1,count);
            count--;
            shiftDown(1);
            return res;
        }
        private void shiftDown(int i)
        {
          int j=2*i;
          while(j<=count)
          {
              if(j+1<=count&&stone[j+1]>stone[j])
              {
                  if(stone[j+1]>stone[i])
                  {
                       swap(j+1,i);
                       i=j+1;
                       j=2*i;
                  }
                  else
                      break;
                 
              }
              else
              {
                  if(stone[j]>stone[i])
                  {
                      swap(j,i);
                      i=j;
                      j=2*i;
                  }
                  else
                      break;
              }
          }
        }  
        public int size()
        {
            return count;
        }
    }

  • 相关阅读:
    (转)浮点数的存储方式
    (转)静态变量和全局变量的区别
    (转)RTMP协议从入门到放弃
    python: format
    Tornado web.authenticated 用户认证浅析
    Python时间,日期,时间戳之间转换
    Python图片处理PIL/pillow/生成验证码/出现KeyError: 和The _imagingft C module is not installed
    Python图像处理库:Pillow 初级教程
    Python练习册--PIL处理图片之加水印
    python中string模块各属性以及函数的用法
  • 原文地址:https://www.cnblogs.com/cold-windy/p/11201338.html
Copyright © 2011-2022 走看看