`

排序算法-选择排序

 
阅读更多

选择排序
基本思路:从所有元素中选择一个最小元素a[i]放在a[0](即让最小元素a[i]与a[0]
交换),作为第一轮;第二轮是从a[1]开始到最后的各个元素中选择一个最小元素,放在a[1]中;……依次类推。n个数要进行(n-1)轮。


算法对比:

冒泡排序:比较的次数与冒泡法一样多,但是在每一轮
      中只进行一次交换,比冒泡法的交换次数少,相对于冒泡法效率高。

插入排序:相对与插入排序来说,选择排序每次选出的都是全局第i小的,不会调整前i个元素了。

 

在这里补充一下,前面两个的一个基础类:

package com.zenoh.algorithms;

public abstract class Sorter<T extends Comparable<T>> {

	/**
	 * 排序算法函数
	 * 
	 * @param array
	 *            数组
	 * @param from
	 *            开始
	 * @param len
	 *            长度
	 */
	public abstract void sort(T[] array, int from, int len);

	public final void sort(T[] array) {
		sort(array, 0, array.length);
	}

	/**
	 * 交换数组的两个元素
	 * @param array
	 * @param from
	 * @param to
	 */
	protected final void swap(T[] array, int from, int to) {
		T tmp = array[from];
		array[from] = array[to];
		array[to] = tmp;
	}

}

 

public class SelectSorter<T extends Comparable<T>> extends Sorter<T> {

	/**
	 * 选择排序
	 */
	@Override
	public void sort(T[] array, int from, int len) {
		 for(int i=0;i<len;i++)
	        {
	            int smallest=i;
	            int j=i+from;
	            for(;j<from+len;j++)
	            {
	                if(array[j].compareTo(array[smallest])<0)
	                {
	                    smallest=j;
	                }
	            }
	            swap(array,i,smallest);
	                   
	        }

	}

	
	/**
	 * 测试	
		 * @param args
		 */
		public static void main(String[] args) {
			Integer array[] = {2,35,5,78,1,90,13,56} ;
			for (int i = 0 ; i<array.length ; i++){
				System.out.print(array[i]+",");
			}
			System.out.println();
			Sorter sorter = new SelectSorter<Integer>() ;
			sorter.sort(array) ;
				
			for (int i = 0 ; i<array.length ; i++){
				System.out.print(array[i]+",");
			}				
			}
}

 

分享到:
评论

相关推荐

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

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

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

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

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

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

    经典算法的C#源码实现

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

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

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

    java排序算法-大全.rar

    在编程领域,排序算法是计算机科学中的核心概念,特别是在Java这样的高级编程语言中。这个名为"java排序算法-大全.rar"的压缩包文件显然包含了多种Java实现的排序算法,这对于我们理解和掌握这些算法至关重要。 ...

    FPGA并行快速排序算法-位宽可设

    在本文中,我们将深入探讨基于FPGA的并行快速排序算法,特别关注“位宽可设”的特性。这种算法能够高效地处理大量数据,并且在硬件实现上具有很高的灵活性。我们将从以下几个方面来阐述这个主题: 一、快速排序算法...

    数字排序 - 排序算法 - 排序

    比较排序算法通过比较两个元素的大小来决定它们的顺序,典型的比较排序算法有冒泡排序、选择排序、插入排序、快速排序、归并排序和堆排序等。非比较排序则是通过直接计算出元素最终的位置来进行排序,如计数排序、...

    常用排序算法--堆排序

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

    排序算法 - 算法刷题 -算法资源

    不同的排序算法在时间复杂度、空间复杂度以及适用场景方面有着显著的差异,选择合适的排序算法对于优化程序性能至关重要。 常见的排序算法包括冒泡排序、选择排序、插入排序、快速排序、归并排序、堆排序、希尔排序...

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

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

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

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

    排序算法--免费

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

    排序算法-SortingAlgorithm-java.zip

    选择排序算法在时间复杂度上是O(n^2),它的优点是简单易懂,缺点是效率较低,因为每次只能确定一个元素的位置。 2. 冒泡排序 Bubble Sort:冒泡排序是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个...

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

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

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

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

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

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

    理解插入排序算法-讲解

    理解插入排序算法-讲解

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

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

    排序算法-python

    排序算法有很多种,比如常见的冒泡排序、选择排序、插入排序、快速排序、归并排序、堆排序、希尔排序等。每种排序算法都有自己的特点和适用场景,这需要根据实际需求来选择合适的排序方法。 对于Python语言而言,它...

Global site tag (gtag.js) - Google Analytics