材料:猴子排序,按照身高来从小到大来排序。

第一关:

老猴子带领小猴子队伍按大小逐一比较,交换,开始高矮排列队伍。(冒泡排序)

第二关:

太慢了,给第一关增加难度,进行选择排序

第三关:

最后,尝试选择用插入排序法,来进行排序。

测试类:

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader; //功能:猴子排序
public class MonkeySelect { public static void main(String[] args) {
// TODO Auto-generated method stub
// 定义一个可以装5只猴子的对象数组
int size = 5;
Monkey[] monkeys = new Monkey[size]; InputStreamReader isr = new InputStreamReader(System.in);
BufferedReader br = new BufferedReader(isr);
// 初始化各个猴子
for (int i = 0; i < monkeys.length; i++) {
System.out.println("请输入第" + (i + 1) + "只猴子的高度"); try {
String height = br.readLine();
monkeys[i] = new Monkey((i + 1) + "", Float.parseFloat(height));
} catch (NumberFormatException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
// 让老猴子排序
Monkey oldMonkey = new Monkey("1000", 1.2f);
// 冒泡排序
oldMonkey.bubbleSort(monkeys); // oldMonkey.selectSort(monkeys);选择排序调用
// oldMonkey.insertSort(monkeys);插入排序调用 // 验证
oldMonkey.show(monkeys);
}
}

猴子类(功能):

// 猴子
class Monkey {
private String monkeyId;
private float height; public Monkey(String monkeyId, float height) {
this.monkeyId = monkeyId;
this.height = height;
} // 插入排序
public void insertSort(Monkey[] monkeys) {
// 开始排序
for (int i = 0; i < monkeys.length; i++) {
// 先记录该猴子的身高
float insertHeight = monkeys[i].height;
String insertNo = monkeys[i].monkeyId;
int insertIndex = i - 1; while (insertIndex >= 0
&& monkeys[insertIndex].height > insertHeight) {
monkeys[insertIndex + 1].height = monkeys[insertIndex].height;
monkeys[insertIndex + 1].monkeyId = monkeys[insertIndex].monkeyId;
insertIndex--;
}
// 插入
monkeys[insertIndex + 1].height = insertHeight;
monkeys[insertIndex + 1].monkeyId = insertNo;
}
} // 选择排序
public void selectSort(Monkey[] monkeys) {
float tempHeight = 0.0f;
String tempNo = "";
for (int i = 0; i < monkeys.length; i++) { float minHeight = monkeys[i].height;
int minIndex = i; // 和后面的比较
for (int j = i + 1; j < monkeys.length; j++) {
if (minHeight > monkeys[j].height) {
// 修正一下最小值
minHeight = monkeys[j].height;
// 修正下标
minIndex = j;
}
}
if (minIndex != i) {
// 交换
tempHeight = monkeys[minIndex].height;
monkeys[minIndex].height = monkeys[i].height;
monkeys[i].height = tempHeight; tempNo = monkeys[minIndex].monkeyId;
monkeys[minIndex].monkeyId = monkeys[i].monkeyId;
monkeys[i].monkeyId = tempNo;
}
}
} // 冒泡排队
public void bubbleSort(Monkey[] monkeys) {
float tempHeight = 0.0f;
String tempNo = ""; // 冒泡
for (int i = 0; i < monkeys.length - 1; i++) {
for (int j = 0; j < monkeys.length - 1 - i; j++) {
// 判断
if (monkeys[j].height > monkeys[j + 1].height) {
// 身高
tempHeight = monkeys[j].height;
monkeys[j].height = monkeys[j + 1].height;
monkeys[j + 1].height = tempHeight;
// 编号
tempNo = monkeys[j].monkeyId;
monkeys[j].monkeyId = monkeys[j + 1].monkeyId;
monkeys[j + 1].monkeyId = tempNo; }
}
} } // 显示队列
public void show(Monkey[] monkeys) {
for (int i = 0; i < monkeys.length; i++) {
System.out.println("猴子编号:" + monkeys[i].monkeyId + " 身高:"
+ monkeys[i].height);
}
}
}

过三关 Java冒泡排序选择排序插入排序小练习的更多相关文章

  1. java冒泡排序-选择排序-插入排序-使用API中文文档直接调用函数

    import java.util.Arrays; public class ArrayDemo2_3 { public static void main(String []args) { //---- ...

  2. 学习C#之旅 冒泡排序,选择排序,插入排序,希尔排序[资料收集]

    关于冒泡排序,选择排序,插入排序,希尔排序[资料收集]  以下资料来源与网络 冒泡排序:从后到前(或者从前到后)相邻的两个两两进行比较,不满足要求就位置进行交换,一轮下来选择出一个最小(或最大)的放到 ...

  3. python算法(一)基本知识&冒泡排序&选择排序&插入排序

    本节内容: 算法基本知识 冒泡排序 选择排序 插入排序 1. 算法基本知识 1.1 什么是算法? 算法(algorithm):就是定义良好的计算过程,他取一个或一组的值为输入,并产生出一个或一组值作为 ...

  4. 数组排序-冒泡排序-选择排序-插入排序-希尔排序-快速排序-Java实现

    这五种排序算法难度依次增加. 冒泡排序: 第一次将数组相邻两个元素依次比较,然后将大的元素往后移,像冒泡一样,最终最大的元素被移到数组的最末尾. 第二次将数组的前n-1个元素取出,然后相邻两个元素依次 ...

  5. 冒泡排序 选择排序 插入排序希尔排序 java

    双向冒泡 package com.huang; public class _014_bubb_sort { int[] b={1,2}; static int a[]={12,4,35,65,43,6 ...

  6. 冒泡排序 & 选择排序 & 插入排序 & 希尔排序 JavaScript 实现

    之前用 JavaScript 写过 快速排序 和 归并排序,本文聊聊四个基础排序算法.(本文默认排序结果都是从小到大) 冒泡排序 冒泡排序每次循环结束会将最大的元素 "冒泡" 到最 ...

  7. php基础排序算法 冒泡排序 选择排序 插入排序 归并排序 快速排序

    <?php$arr=array(12,25,56,1,75,13,58,99,22);//冒泡排序function sortnum($arr){    $num=count($arr);    ...

  8. 算法 排序lowB三人组 冒泡排序 选择排序 插入排序

    参考博客:基于python的七种经典排序算法   [经典排序算法][集锦]     经典排序算法及python实现 首先明确,算法的实质 是 列表排序.具体就是操作的列表,将无序列表变成有序列表! 一 ...

  9. lowB三人组算法-冒泡排序-选择排序-插入排序

    冒泡排序 时间复杂度:O(n2)  算法稳定 第一趟,从第一个数开始,相邻两个数比较,大的数交换放后,交换到最后位置得出一个第一大数 第二趟,从第一个数开始,相邻两个数比较,大的数交换放后,交换到倒数 ...

随机推荐

  1. 读取嵌入到word的Excel对象

    Word.Document doc = this._wordApplication.Documents.Add(@"C:\Users\linmeicheng\Desktop\新建文件夹 (3 ...

  2. VS2015 类模板保存位置

    如果安装在C盘,则是如下位置: C:\Program Files (x86)\Microsoft Visual Studio 14.0\Common7\IDE\ItemTemplates\CSharp ...

  3. 初识Twisted(一)

    pip install Twisted 安装Twisted库 from twisted.internet import reactor #开启事件循环 #不是简单的循环 #不会带来任何性能损失 rea ...

  4. 关于 redis的操作

    1.修改配置文件 redis.conf是redis的配置文件,redis.conf在redis源码目录. 注意修改port作为redis进程的端口,port默认6379.如果需要搭建redis集群,千 ...

  5. 微信小程序scroll-view 横向和纵向scroll-view组件

    scroll-view为滚动视图,分为水平滚动和垂直滚动.注意滚动视图垂直滚动时一定要设置高度否则的话scroll-view不会生效.滚动视图常用的地方一般都是Item项比较多的界面,比如我的模块 主 ...

  6. VMware Tools安装教程

    安装依赖: sudo yum install eject 步骤: 确保 Linux 虚拟机已打开电源. 如果正在运行 GUI 界面,请打开命令 shell. 注意:以 root 用户身份登录,或使用 ...

  7. VRRP&HSRP

    HSRP 活跃路由器和备用路由器都会向组播地址 224.0.0.2  UDP 1985  端口发送hello消息. VRRP组中有一台主用路由器(Master),以及一台或多台备用路由器(Backup ...

  8. jsp页面跳转页面的几中方式(同步更新)

    1. 通过<a>标签跳转网页a) 通过<a>标签直接跳转b) 通过<a>标签调用JavaScript函数,然后再进行跳转 2. 通过表单形式跳转网页a) 通过表单跳 ...

  9. 程序性能调优工具之gprob

    1 简介改进应用程序的性能是一项非常耗时耗力的工作,但是究竟程序中是哪些函数消耗掉了大部分执行时间,这通常都不是非常明显的.GNU 编译器工具包所提供了一种剖析工具 GNU profiler(gpro ...

  10. 彻底理解Java中的基本数据类型转换(自动、强制、提升)

    说基本数据类型转换之前,先了解下 Java 中的 8 种基本数据类型,以及它们的占内存的容量大小和表示的范围,如下图所示. 重新温故了下原始数据类型,现在来解释下它们之间的转换关系. 自动类型转换 自 ...