码迷,mamicode.com
首页 > 编程语言 > 详细

自己写算法---java的堆的非递归遍历

时间:2015-09-15 12:52:31      阅读:243      评论:0      收藏:0      [点我收藏+]

标签:

import java.io.*;
import java.util.*;
public class Main
{
    public static void main(String args[])
    {
        Scanner cin = new Scanner(System.in);
      //ArrayList<String> list = new ArrayList<String>();
      //Scanner scan = new Scanner(System.in); //获取键盘输入的另一种格式
        int[] list={};  //如果只是在外部申明而没有静态初始化的话,while里面的数组将变为局部变量,从而在循环外部无法获取
        while(cin.hasNextInt())
        {   
            int    s=cin.nextInt();
            list = new int[s];         // 声明数组长度
            for(int i=0;i<list.length;++i){ //给数组赋值
             list[i] = cin.nextInt();
            }
            break;
        }    
        //以下是具体算法,堆排序(非递归)
        //1.初始化堆
          list = confirm(list,list.length);
        //2.开始堆排序

        for(int j=list.length-1;j>=0;--j){
         int tmp=list[j];
         list[j]=list[0];
         list[0]=tmp;
         list = confirm(list,j); //最后一个不需要比较           
        }

     for(int i=0;i<list.length;++i){
                System.out.println(list[i]);
             }
    }

//初始化堆的方法
public static int[] init(int[] list,int cycnum){
           for(int i=cycnum-1;i>=0;--i){
               if(2*i+1>cycnum-1){
                continue;  //到最底层叶子节点时,跳出循环
            }
            int max=0;//记录左右节点较大的一个,值的大小
            int key=0;//记录key的大小
            if(2*i+2>cycnum-1){
                    max=list[2*i+1];
                    key=2*i+1;
            }else{
                    max=list[2*i+1]>list[2*i+2] ? list[2*i+1]:list[2*i+2];
                    key=list[2*i+1]>list[2*i+2] ? 2*i+1 : 2*i+2;
            }
            if(max>list[i]){        
                    list[key]=list[i];
                    list[i]=max;
            }
        }
    return list;
 }

 public static int[] confirm(int[] list,int cycnum){
   for(int j=0;j<=cycnum;++j){  
             list  =   init(list,cycnum); //调用堆的方法,只是调用for循环,没有递归
              if( list  ==   init(list,cycnum)){
                break;
              }
          }
          return list;
 }
}

 

自己写算法---java的堆的非递归遍历

标签:

原文地址:http://www.cnblogs.com/yuqiandoudou/p/4809662.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!