各种排序

package qinglin.learn.arithmetic;


public class SortsServices
{
public static void main(String args[])
{
SortsServices.sortIntoAction(1);
}
/**
* 交换值,交换数组的两个值
* @param array
* @param i
* @param j
*/
private static void swap(int[] array, int i, int j)
{
int tmp = array[i];
array[i] = array[j];
array[j] = tmp;
}

/**
*
* @param method
* 1为升序,2为降序
*/
public static void sortIntoAction(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]);
}
}

/**
* 取随机数据,初始化一个数组
*
* @param min
* 随机数的最小值
* @param max
* 最大值
* @param size
* 取得随机数的数量
* @return
*/
public static int[] initArray(int min, int max, int size)
{
int[] init = new int[size];

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

/**
* 交换排序方法
* 原理:依次交换值
* @param array
* @return
*/
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;
}

/**冒泡排序方法
* 原理:从最后一个开始将小的或大的逐渐冒出
* @param array
* @param method
* @return
*/
public static int[] bubbleOrder(int[] array, int method)
{
for (int i = 0; i < array.length; 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;
}

/**
* 双向冒泡排序
* 原理:类似于冒泡排序,只不过是双向的
* @param array
* @param method
* @return
*/
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;
}

/**
* 快速排序方法,运用到递归
* 排序原理:随机找到一个值,然后以此值大小进行分为两个数组,大的放左边,小的放右边,
* 然后再对左右两侧的数据依次排序根据
* @param array
* @param method
* @return
*/
public static int[] quickOrder(int[] array, int method)
{
quickDeal(array, 0, array.length - 1, method);
return array;
}

/**
*
* @param array
* @param begin
* 开始位置
* @param end
* 结束位置
*/
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);
}

}

/**
* 插入排序方法
* 排序原理:抽出一个数,做为排序基序列,然后依次抽出其它数与,与此序列中的数进行比较,放入合适的位置
* @param array
* @param method
* @return
*/
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;
}

/**
* 选择排序方法
* 排序原理:每次选择一个最大的或最小的数放到已排序序列中
* @param array
* @param method
* @return
*/
public static int[] selectOrder(int[] array, int method)
{
for (int i = 0; i < array.length - 1; i++)
{
int tmp = array[i];
int pos = i + 1; //记录大值或小值的位置 
for (int j = i + 1; j < array.length; j++)
{
if (method == 1)
{
if (array[j] < tmp)
{
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;
}

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值