`
xieyan30
  • 浏览: 49064 次
  • 性别: Icon_minigender_1
文章分类
社区版块
存档分类
最新评论

排序算法 -- 选择排序

 
阅读更多

选择排序
从序列的第一位开始,找到最小(大)值,把该值与第一位上的值交换,接着从第二个位置开始重复此动作。

 

效率不高,容易实现。

 

/**
 * SelectionSort.java
 * 
 * @author   xieyan
 * @date     2013/06/20
 * @version  1.0
 */
package sort;

/**
 * SelectionSort.java
 */
public class SelectionSort {

	/*
	 * 选择排序
	 * 从序列的第一位开始,找到最小(大)值,把该值与第一位上的值交换,接着从第二个位置开始重复此动作。
	 * 
	 * 效率不高,容易实现
	 */

	/**
	 * selectionSortAsc
	 * 
	 * <PRE>
	 * 升序
	 * </PRE>
	 * 
	 * @param arr
	 */
	public static int[] selectionSortAsc(int[] arr) {
		int min = 0;
		int minLocal = 0;
		for(int i = 0; i < arr.length; i++) {
			min = arr[i];
			minLocal = i;
			for(int j = i + 1; j < arr.length; j++) {
				if(min > arr[j]) {
					min = arr[j];
					minLocal = j;
				}
			}
			arr[minLocal] = arr[i];
			arr[i] = min;
		}
		
		return arr;
	}

	/**
	 * selectionSortDesc
	 * 
	 * <PRE>
	 * 降序
	 * </PRE>
	 * 
	 * @param arr
	 */
	public static int[] selectionSortDesc(int[] arr) {
		int min = 0;
		int minLocal = 0;
		for(int i = 0; i < arr.length; i++) {
			min = arr[i];
			minLocal = i;
			for(int j = i + 1; j < arr.length; j++) {
				if(min < arr[j]) {
					min = arr[j];
					minLocal = j;
				}
			}
			arr[minLocal] = arr[i];
			arr[i] = min;
		}
		
		return arr;
	}

	public static void main(String[] args) {
		int[] a = new int[] { 5, 7, 8, 3, 4, 2, 9, 1, 6 };

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

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

 

分享到:
评论

相关推荐

    堆排序详细图解(通俗易懂)+排序算法-堆排序(超详细)

    堆排序详细图解(通俗易懂)+排序算法----堆排序(超详细)堆排序详细图解(通俗易懂)+排序算法----堆排序(超详细)堆排序详细图解(通俗易懂)+排序算法----堆排序(超详细)堆排序详细图解(通俗易懂)+排序算法...

    最快的排序算法 计算机最快的算法-史上14个最快速算法:孩子的计算能力爆表!大脑堪比计算机!...,排序算法数据结构

    选择排序算法也是一种简单的排序算法,它的工作原理是通过选择最小或最大元素,并将其与第一个元素交换,以达到排序的目的。选择排序算法的时间复杂度也为O(n^2),因此它也适合小规模的数据排序。 3.插入排序算法 ...

    详解Java常用排序算法-选择排序

    详解Java常用排序算法-选择排序 选择排序(Selection Sort)是一种简单的排序算法,它的基本思想是每次从待排序的元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的元素排完。 选择...

    经典算法的C#源码实现

    经典排序算法 - 选择排序Selection sort 经典排序算法 - 鸡尾酒排序Cocktail sort 经典排序算法 - 希尔排序Shell sort 经典排序算法 - 堆排序Heap sort序 经典排序算法 - 地精排序Gnome Sort 经典排序算法 - ...

    常用排序算法--堆排序

    常用的排序算法--堆排序,通过创建堆的方法进行排序

    c语言链表的排序算法-排序链表最快的算法是什么?.pdf

    因此,选择合适的排序算法对于链表的性能至关重要。 在这篇文章中,我们将讨论链表排序算法的性能分析和优化。我们将比较不同的排序算法,包括合并排序和快速排序,并分析它们在链表中的性能。 首先,让我们讨论...

    C#-基于C#实现的选择排序算法-Selection-Sort.zip

    总的来说,C#中的选择排序算法是一种基础排序算法,虽然在实际应用中可能不是最佳选择,但了解其原理和实现有助于提升对排序算法的理解。通过这个项目,你可以学习到如何在C#中编写排序算法,并进行实际的代码实践。

    排序算法--免费

    本文将深入探讨标题和描述中提到的一些基本排序算法,包括选择排序、冒泡排序、插入排序、希尔排序、堆排序、快速排序以及归并排序,并结合C++编程语言进行讲解。 1. **选择排序(Selection Sort)** - 选择排序是一...

    排序算法 - Axb的自我修养1

    【排序算法概述】 ...在实际应用中,应根据数据规模、数据分布以及内存限制等因素选择合适的排序算法,以实现最佳性能。同时,优化排序算法也是提高程序效率的重要手段,例如通过并行化、缓存优化等方法。

    详解Java常用排序算法-插入排序

    Java排序算法 - 插入排序 插入排序(Insertion Sort)是一种简单的排序算法,它的基本思想是将一个记录插入到已经排好序的有序表中,从而得到一个新的、记录数增 1 的有序表。该算法的实现非常简单,但其时间复杂度...

    简单排序算法--类的简单使用

    在这个例子中,可能会有一个类`SortAlgorithms`包含各种排序算法的成员函数,如冒泡排序、选择排序、插入排序、快速排序等。另一个类`UserInterface`则负责处理用户交互和控制执行哪种排序算法。 3. **排序算法的...

    实现经典的排序算法--R语言_sort-algorithm.zip

    实现经典的排序算法--R语言_sort-algorithm

    理解插入排序算法-讲解

    理解插入排序算法-讲解

    数据结构--九种排序算法 --排序001.cpp

    此文件为数据结构中的九种排序算法,包含一些排序方法的过程,其九种排序包括:直接插入排序,折半插入排序,希尔排序,冒泡排序,快速排序,选择排序,堆排序,归并排序,基数排序!

    排序算法-插入排序

    插入排序是一种基础且直观的排序算法,它的工作原理...通过理解插入排序的工作原理和特性,我们可以更好地利用它来解决实际问题,并根据需要选择合适的排序算法。对于学习和理解排序算法,插入排序是一个很好的起点。

    基于python的排序算法-选择排序Selection Sort

    选择排序是一种简单直观的排序算法,它的工作原理是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。这种排序方式在Python编程中有着广泛的应用。...

    排序算法-StdDraw动态展示源码

    - **堆排序**:利用堆这种数据结构所设计的一种排序算法,可以看作是一种选择排序的优化。 3. ** 动态展示** 源码中的动态展示部分,通过对每一步操作进行绘制,让学习者能够观察到: - 冒泡排序中的气泡如何...

    JavaScript-使用javascript开发的排序算法-sorting.zip

    在这个"JavaScript-使用javascript开发的排序算法-sorting.zip"压缩包中,很可能是包含了各种常见的排序算法实现,比如冒泡排序、插入排序、选择排序、快速排序、归并排序以及堆排序等。 1. **冒泡排序**:冒泡排序...

    排序算法--比较类排序

    我写的一个内排序的博客算法的一个总结,全部代码在这个里面,需要的就看看吧!!还需要什么请联系我,我有就发!!

Global site tag (gtag.js) - Google Analytics