1 问题描述

给定一个可排序的n元素序列(例如,数字、字符和字符串),将它们按照非降序方式重新排列。

2 解决方案

2.1 选择排序原理简介


选择排序开始的时候,我们从第一个元素开始扫描整个列表,找到它的最小元素,然后和第一个元素交换,将最小元素和第一个元素交换位置;然后,我们从第二个元素开始扫描剩下的n-1个元素,找到这n-1个元素中的最小元素,将最小元素和第二个元素交换位置;然后从第三个元素开始扫描…一般来说,就是从第i个元素开始扫描,找到第n-i+1个元素中的最小元素,将最小元素与第i个元素交换位置。这样,在进行n-1次遍历后,该列表就排好序了。

package com.liuzhen.chapterThree;

public class SelectionSort {

    public static void getSelectionSort(int[] a){
int min = 0; //用于存放n-i序列中最小元素序号
int temp = 0; //交换数组元素值的中间变量
//打印输出未排序前数组序列
System.out.print("排序前: ");
for(int p = 0;p < a.length;p++)
System.out.print(a[p]+"\t");
System.out.println(); for(int i = 0;i < a.length-1;i++){
min = i;
for(int j = i+1;j < a.length;j++){
if(a[j] < a[min])
min = j;
}
//交换a[i]和a[min]的值
temp = a[i];
a[i] = a[min];
a[min] = temp;
//打印输出每一次选择排序结果
System.out.print("排序第"+(i+1)+"趟:");
for(int p = 0;p < a.length;p++)
System.out.print(a[p]+"\t");
System.out.println();
}
} public static void main(String args[]){
int[] a = {89,45,68,90,29,34,17};
getSelectionSort(a);
}
}

运行结果:

排序前:   89    45    68    90    29    34    17
排序第1趟:17 45 68 90 29 34 89
排序第2趟:17 29 68 90 45 34 89
排序第3趟:17 29 34 90 45 68 89
排序第4趟:17 29 34 45 90 68 89
排序第5趟:17 29 34 45 68 90 89
排序第6趟:17 29 34 45 68 89 90

2.3 冒泡排序原理简介

我们从列表的第一个元素开始,比较列表中相邻的两个元素,如果第一个元素大于第二元素,则交换这两个元素的位置,否则就从第二个元素位置开始重复上一步操作。重复多次以后,最大的元素就“沉到”列表的最后一个位置。这样一直做,直到n-1遍以后,该列表就排好序了。

package com.liuzhen.chapterThree;

public class BubbleSort {

    public static void getBubbleSort(int[] a){
int temp;
//打印输出未排序前数组序列
System.out.print("排序前: ");
for(int p = 0;p < a.length;p++)
System.out.print(a[p]+"\t");
System.out.println();
for(int i = 0;i < a.length-1;i++){
for(int j = 0;j < a.length-1-i;j++){
if(a[j+1] < a[j]){
//交换a[j]和a[j+1]的值
temp = a[j];
a[j] = a[j+1];
a[j+1] = temp;
}
}
//打印输出每一次选择排序结果
System.out.print("排序第"+(i+1)+"趟:");
for(int p = 0;p < a.length;p++)
System.out.print(a[p]+"\t");
System.out.println();
}
} public static void main(String args[]){
int[] a = {89,45,68,90,29,34,17};
getBubbleSort(a);
}
}

运行结果:

排序前:   89    45    68    90    29    34    17
排序第1趟:45 68 89 29 34 17 90
排序第2趟:45 68 29 34 17 89 90
排序第3趟:45 29 34 17 68 89 90
排序第4趟:29 34 17 45 68 89 90
排序第5趟:29 17 34 45 68 89 90
排序第6趟:17 29 34 45 68 89 90

Java实现选择排序和冒泡排序的更多相关文章

  1. Java中选择排序,冒泡排序,插入排序,快速排序

    一:冒泡法排序  //冒泡排序 注:从小到大排   //特点:效率低,实现简单  //思想:每一趟将待排序序列中最大元素移到最后,剩下的为新的待排序序列,重复上述步骤直到排完所有元素. 这只是冒泡排序 ...

  2. Java实现选择排序以及冒泡排序

    //排序 选择排序 数组中每个元素都进行比较 public class Test { public static void main(String[] args) { int[] arr = {12, ...

  3. Java基础——选择排序、冒泡排序

    1.选择排序 原理是直接从待排序数组里选择一个最小(或最大)的数字,每次都拿一个最小数字出来, 顺序放入新数组,直到全部拿完 代码演示: public class Test3 { public sta ...

  4. java 选择排序、冒泡排序、折半查找

    public class SortAndSelectDemo{ public static void main(String[] args){ int[] arr = {3, 5, 17, 2, 11 ...

  5. java 选择排序与冒泡排序

    选择排序与冒泡排序的特点与区别 ++++++++++++++++++++++++++++++++++++++++++++++ 选择排序 这一种简单的排序方法,它的基本思想是:R[n]第一次从R[0]~ ...

  6. JAVA简单选择排序算法原理及实现

    简单选择排序:(选出最小值,放在第一位,然后第一位向后推移,如此循环)第一位与后面每一个逐个比较,每次都使最小的置顶,第一位向后推进(即刚选定的第一位是最小值,不再参与比较,比较次数减1) 复杂度: ...

  7. Java-数据结构与算法-选择排序与冒泡排序

    Java 选择排序与冒泡排序 1.DataSorter.java public class DataSorter { //冒泡排序法 //主要思路:按升序排序,数组元素两两比较,大的立即排后面 pub ...

  8. 算法——蛮力法之选择排序和冒泡排序c++实现

    这次实现的是蛮力法中的两个例子,选择排序法和冒泡排序法,使用的编译环境是vs2013,下面对这两个算法做一个简单介绍,然后是两个算法的c++实现代码. 选择排序法比较的范围是整个列表,每次扫描结束找出 ...

  9. C语言排序算法之简单交换法排序,直接选择排序,冒泡排序

    C语言排序算法之简单交换法排序,直接选择排序,冒泡排序,最近考试要用到,网上也有很多例子,我觉得还是自己写的看得懂一些. 简单交换法排序 /*简单交换法排序 根据序列中两个记录键值的比较结果来对换这两 ...

随机推荐

  1. [hdu5247]rmq+预处理

    题意:有一个无序数组,求有多少个长度为k的区间满足把区间内的数排序后是连续的. 思路:长度为k的区间排序后是 连续的数等价于maxval-minval等于k-1并且不同的数有k个(或者说没有相同的数) ...

  2. 盘点6个Kubernetes监视工具

    导读:监控可帮助您确保Kubernetes应用程序平稳运行并排除可能出现的任何问题.Prometheus是一种流行的开源监视工具,许多公司都使用它来监视其IT基础结构.但是,还有许多其他监视工具可用. ...

  3. 【题解】合唱队形——LIS坑爹的二分优化

     题目 [题目描述]N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形.合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2…,K,他们的身高分别为T1 ...

  4. webpack的proxytable的配置

    这个一定不能忘记了/rest/后面的/,否则就是404找不到接口 这样的实现效果是 this.axios.post('/api/delShare', qs.stringify({'Id':Number ...

  5. Java开发架构篇:DDD模型领域层决策规则树服务设计

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 在上一章节介绍了领域驱动设计的基本概念以及按照领域驱动设计的思想进行代码分层,但是仅 ...

  6. spark机器学习从0到1主成分分析-PCA (八)

      PCA 一.概念 主成分分析(Principal Component Analysis)是指将多个变量通过线性变换以选出较少数重要变量的一种多元统计分析方法,又称为主成分分析.在实际应用场合中,为 ...

  7. 微信小程序前端与myeclipse的数据交换过程(SSH)

    这是我个人探究微信小程序前端与后端之间的数据交换的过程,再结合个人所学的SSH框架, 编程工具用myEclipse2014工具.当然,前提是后台的项目要部署到tomcat服务器上才行, 然后总结了从后 ...

  8. React中父子组件数据传递

    Vue.js中父子组件数据传递:Props Down ,  Events Up Angular中父子组件数据传递:Props Down,  Events  Up React中父子组件数据传递:Prop ...

  9. 关于 Git 拉取GitLab工程报错:Repository not found的问题

    [root@localhost xscan]# git pull fatal: repository 'http://gitlab.***.com/***.git/' not found 原因1: 可 ...

  10. thinkphp路由简介和设置使用

    use think\Route; //静态路由 Route::rule('/', 'index/index/index'); Route::rule('test', 'index/index/test ...