package dasf;
public class Sort {
/** 创建一新数组 */
private static int[] numArray = { 5, 12, 2, 63, 22, 6, 54, 42 };
/** 计算新数组的长度 */
private static int count = numArray.length;
/**
* 构造方法
*/
protected Sort() {
}
/**
* 程序的唯一入口 main 方法
*
* @param args
*/
public static void main1(String[] args) {
BubbleSort(numArray);
/** 输出 */
for (int i = 0; i < count; i++) {
System.out.print(numArray[i] + "\t");
}
}
/**
* 选择
*/
public static void SelectSort(int[] array) {
for (int i = 0; i < array.length; i++) {
// 最大值得位置
int max = i;
for (int j = i+1; j < array.length; j++) {
if(array[max] < array[j]){
max = j;
}
}
swap(array,i,max);
}
}
/**
* 插入法排序
*/
public static void InsertSort(int[] array) {
for (int i = 1; i < array.length; i++) {
int tmp = array[i];
int j = i;
while (j > 0 && array[j - 1] < tmp) {
array[j] = array[j - 1];
--j;
}
array[j] = tmp;
}
}
/**
* 冒泡法排序
*/
public static void BubbleSort(int[] array) {
int temp;
for (int i = 0; i < array.length - 1; i++) {
for (int j = i + 1; j < array.length; j++) {
if (array[i] < array[j]) {
temp = array[i];
array[i] = array[j];
array[j] = temp;
}
}
}
}
/**
* 交换数组中i和j的位置
*/
private static void swap(int[] array, int i, int j) {
int tmp = array[i];
array[i] = array[j];
array[j] = tmp;
}
/**
* @param pData 需要排序的数组
* @param left 左边的位置,初始值为0
* @param right 右边的位置,初始值为数组长度
*/
public static void QuickSort(int[] pData,int left,int right)
{
int i,j;
int first,temp;
i = left;
j = right;
first = pData[left]; //这里选其他的数也行,不过一般选第一个
//一趟快速排序
while(true)
{
//从第二个数开始找大于中枢的数 ,从前面开始找大于pData[left]的数
while((++i)<right-1 && pData[i]<first);
//从最后一个数开始找第一个小于中枢pData[left]的数
while((--j)>left && pData[j]>first);
if(i>=j)
break;
//交换两边找到的数
temp = pData[i];
pData[i] = pData[j];
pData[j] = temp;
}
//交换中枢
pData[left] = pData[j];
pData[j] = first;
//递归快排中枢左边的数据
if(left<j)
QuickSort(pData,left,j);
//递归快排中枢右边的数据
if(right>i)
QuickSort(pData,i,right);
}
public static void main(String[] args){
int [] pData = new int[5];
for(int i = 0; i< 5; i++)
pData[i] = (int)(Math.random()*100);//Produce 10 random integers
for(int i = 0; i<pData.length; i++){
System.out.print(pData[i]+" ");
}
QuickSort(pData, 0, pData.length);
System.out.println("\n***********************");
for(int i = 0; i<pData.length; i++){
System.out.print(pData[i]+" ");
}
}
}
分享到:
相关推荐
本文将详细介绍几种常见的Java排序算法,包括它们的工作机制、优缺点以及适用场景。 1. 插入排序 - 直接插入排序:该算法通过将每个元素插入到已排序部分的正确位置来工作。在Java中,可以通过遍历数组,将每个...
Java作为广泛应用的编程语言,提供了丰富的工具和方法来实现各种排序算法。以下是对标题"java各种排序算法"和描述中涉及的知识点的详细说明。 1. **冒泡排序(Bubble Sort)** 冒泡排序是最基础的排序算法之一,通过...
这个名为"Java各种排序算法代码.zip"的压缩包包含了一系列实现不同排序算法的Java源代码。排序算法是计算机科学中的基本概念,用于对一组数据进行排列。下面将详细讨论这些算法及其在Java中的实现。 1. 冒泡排序...
在编程领域,排序算法是数据结构与算法学习中的基础部分,尤其在Java中,了解和掌握各种排序算法对于提升程序性能至关重要。以下是对标题和描述中提到的Java各种排序算法的详细解释,以及它们的实现代码概述。 1)*...
本资料包"Java各种排序算法Demo"聚焦于通过Java代码展示不同的排序算法,旨在帮助开发者理解和应用这些算法。 首先,我们来探讨几种基础的排序算法: 1. **冒泡排序**:冒泡排序是一种简单的排序算法,通过重复...
Java作为一种广泛使用的编程语言,提供了丰富的工具和方法来实现各种排序算法。本篇将详细讲解标题为"Java各种排序算法代码"的知识点,这些代码案例不仅完整,而且能够运行,非常适合学习和实践。 1. 冒泡排序...
本资源"java各种排序算法源码"涵盖了六种常见的排序算法,它们分别是:直接插入排序、希尔排序、冒泡排序、快速排序、直接选择排序和堆排序。接下来,我们将详细探讨这些排序算法的基本原理、特点以及在Java中的实现...
在这个"Java各种排序算法、Java游戏和实例代码集合"中,我们可以深入学习Java编程的核心技术,并通过实践加强理解。以下是一些关键知识点的详细说明: 1. **排序算法**: - **冒泡排序**:是最基础的排序算法之一...
在提供的文件列表中,`SortCode.java`很可能包含了上述各种排序算法的实现代码,可以用来理解和学习这些算法的细节。`sortTest.java`可能是测试这些排序算法的代码,通过运行测试来验证算法的正确性和效率。`...
java各种排序算法实现,仅供参考。java各种排序算法实现,仅供参考。
这里,我们将深入探讨一些常见的Java排序算法,包括它们的工作原理、优缺点以及适用场景。 1. 冒泡排序(Bubble Sort): 冒泡排序是一种简单的交换排序,通过重复遍历数组,比较相邻元素并根据需要交换它们,直到...
本资源包含的是Java实现的各种常见排序算法的代码示例,每个算法都有详细的注释,方便初学者理解和学习。 1. **冒泡排序**:这是一种基础的排序算法,通过不断交换相邻的逆序元素来逐渐把较大的元素推向数组的后部...