A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© LGQ 中级黑马   /  2015-8-1 23:23  /  268 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

import java.lang.Math;
import java.util.Random;


public class OrderTest {

public static void main(String args[]) {
  OrderTest.ExecOrder(2);
}


private static void swap(int[] array,int i, int j)
{
  int tmp = array[i];
  array[i] = array[j];
  array[j] = tmp;
}


public static void ExecOrder(int method) {
  int[] array = null;
  array = initArray(10, 210, 10);
  
   //int[] orderarray = bubbleOrder(array,method);
  int[] orderarray = doubleBubbleOrder(array,method);
  //int[] orderarray = insertOrder(array, method);
  //int [] orderarray = quickOrder(array,method);
  //int[] orderarray = selectOrder(array, method);
  for (int i = 0; i < orderarray.length; i++) {
   System.out.println(orderarray[i]);
  }
}


public static int[] initArray(int min, int max, int size) {
  int[] init = new int[size];

  for (int i = 0; i < size; i++) {
   Random ra = new Random();
   init[i] = min + (int) (Math.random() * (max - min + 1));
   System.out.println(i + "-------" + init[i]);
  }
  return init;
}


public static int[] convertOrder(int[] array, int method) {
  for (int i = 0; i < array.length; i++) {
   for (int j = i + 1; j < array.length; j++)
   {
    if (method==2)
    {
     if (array[i] < array[j])
      swap(array,i,j);
    }else if (method == 1) {
     if (array[i] > array[j])
      swap(array,i,j);
    }
   }
  }
  return array;
}


public static int[] bubbleOrder(int[] array,int method)
{
  for(int i=0;i
  {
   for (int j=array.length -1 ;j>i;j--)
   {
    if (method==2)
    {
     if (array[i] < array[j])
      swap(array,i,j);
    }else if (method==1)
     if (array[i] > array[j])
      swap(array,i,j);
   }
  }
  return array;
}


public static int[] doubleBubbleOrder(int[] array,int method)
{
  int left = 0;
  int right = array.length -1 ;
  while (left < right)
  {
   for(int i=left;i<=right;i++)
   {
    if (method==1)
    {
     if (array[left] > array[i])
      swap(array,left,i);
    }else
    {
     if (array[left] < array[i])
      swap(array,left,i);
    }
   }
   
   for (int i=left+1;i<=right;i++)
   {
    if (method==1)
    {
     if (array[right] < array[i])
      swap(array,right,i);
    }else
    {
     if (array[right] > array[i])
      swap(array,right,i);
     
    }
   }
   left++;
   right--;
  }
  return array;
}


public static int[] quickOrder(int[] array, int method)
{
  quickDeal(array,0,array.length - 1,method);
  return array;
}


private static void quickDeal(int[] array, int begin, int end,int method) {
  if (end > begin) {
   int pos = begin + (int) (Math.random() * (end - begin + 1)); // 计算分隔位置
   int posvalue = array[pos]; // 取得分隔位置的值
   swap(array,pos,end); //将posvalue放到最end的位置
   pos=begin; //初始化pos
   for (int i=begin; i < end; i++) {
    if (method==1)
    {
     if (array[i] < posvalue) { //当小于posvalue时,将此值移动到pos位置,也就是向前移动
      swap(array,pos,i);
      pos++; //移动后pos增1
     }
    }else if(method == 2)
    {
     if (array[i] > posvalue) { //当小于posvalue时,将此值移动到pos位置,也就是向前移动
      swap(array,pos,i);
      pos++; //移动后pos增1
     }
    }
   }
   swap(array,pos,end); //end位置的值前移
   quickDeal(array,begin,pos -1,method);
   quickDeal(array,pos+1,end,method);
  }

}


public static int[] insertOrder(int[] array, int method) {

  for (int i = 1; i < array.length; i++) {
   if (method == 1) {
    if (array[i - 1] > array[i]) {
     int tmp = array[i]; //
     int j = i - 1;
     do {
      array[j + 1] = array[j];
      j--;
     } while (j >= 0 && tmp < array[j]); //当j>=0并且当前值大于数据中j位置的值时移动
     array[j + 1] = tmp; //插入排序值
    }
   } else if (method == 2) {
    if (array[i - 1] < array[i]) {
     int tmp = array[i];
     int j = i - 1;
     do {
      array[j + 1] = array[j];
      j--;
     } while (j >= 0 && tmp > array[j]);
     array[j + 1] = tmp;
    }
   }
  }
  return array;
}


    public static int[] selectOrder(int[] array,int method)
    {
     for (int i=0;i
     {
      int tmp = array[i];
      int pos = i+1; //记录大值或小值的位置 
      for (int j=i+1;j
      {
       if (method==1)
       {
           if (array[j]
           {
            tmp = array[j];
            pos= j ;//记录大值或小值的位置
           }
       }else if (method==2)
       {
           if (array[j]>tmp)
           {
            tmp = array[j];
            pos= j ;//记录大值或小值的位置
           }
       }
      }
      if (tmp != array[i])
       swap(array,i,pos); //不相同时交换
     }
     return array;
    }

   
}

2 个回复

倒序浏览
。。各种。。。我以为有希尔。堆排。快排之类的。。。。
回复 使用道具 举报
Wqi 发表于 2015-8-1 23:50
。。各种。。。我以为有希尔。堆排。快排之类的。。。。

没呢,刚开始学,都是简单的
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马