在网上看到一个视频将各种排序用视频表示出来,配上音乐,挺好玩的样子,就算是不会编程的人看到也会觉得很舒服,碰巧我也正在写归并算法,于是就用java的GUI实现一个。

  归并排序的时间复杂度是T(n)=O(nlgn),据说是比较排序的时间复杂度下限,缺点是排序算法和合并算法并不在同一空间,使得空间复杂度会有所提升。插入排序避免了归并排序的这一缺点但是又有一新缺点:空间复杂度为O(n2)..插入排序通过二分法改进就不同了,他是前二者的合体,既不在原地排序时间复杂度还是O(n2)……哈哈,开个玩笑。真正的合二者之优点为一的是堆排序,不过目前还没看懂堆排序~看懂了再来记一个。

  话不多说代码如下:

 package com.wyb.dyi.test;

 import java.awt.Color;
import java.awt.Graphics;
import java.awt.Toolkit;
import java.util.Random; import javax.swing.JFrame;
import javax.swing.JPanel; public class ShowMergeSort {
static int[] array = getArray(Tool.W);/* 获得长度为屏幕宽度的乱序数组 */
static updateShowArrayImg m = new updateShowArrayImg(array);/* 先显示当前乱序数组 */ /**
* 归并排序,并将排序过程打印成图像
* @param args
*/
public static void main(String[] args) {
MyJPanel show = m.show;
/* 开局暂停两秒 */
try {
Thread.currentThread();
Thread.sleep(2000);
} catch (Exception e) {
} /* 开始归并排序 */
m.updateShowArray(array);
devide(array, 0, array.length - 1);
m.updateShowArray(array);
} /* 构造一个长度为length的高度为length/2的数组 */
public static int[] getArray(int length) {
/* 生成空数组 */
int[] re = new int[length];
/* 给数组附上高为length/2的升序数值 */
for (int i = 0; i < re.length; i++)
re[i] = i / 2;
/* 讲有序数组打乱 */
for (int i = 0; i < 20 * re.length; i++) {
int index1 = new Random().nextInt(length);
int index2 = new Random().nextInt(length);
int temp = re[index1];
re[index1] = re[index2];
re[index2] = temp;
} return re;
} /* 分解数据 */
public static void devide(int[] array, int left, int right) { if (left < right) {
/* 寻找到中间下标 */
int mid = (right + left) / 2;
/* 从中间下标隔断,将前后两段分别分解 */
devide(array, left, mid);
/* 继续分割第二段 */
devide(array, mid + 1, right);
/* 分割完了,调用归并 */
merge(array, left, mid, mid + 1, right);
}
} /* 归并,包含排序 */
public static void merge(int[] array, int leftStart, int leftEnd,
int rightStart, int rightEnd) {
/* 新建临时数组,存放该次归并后的数据 */
int[] temp = new int[array.length];
/* 记录归并的左组和右组开始结束下标 */
int ls = leftStart, le = leftEnd, rs = rightStart, re = rightEnd;
/* 记录临时数组的存放位置 */
int index = ls;
/* 第一次比较归并,左组合右组中较小的入temp */
while (ls <= le && rs <= re) {
if (array[ls] <= array[rs]) {
temp[index] = array[ls];
index++;
ls++;
} else {
temp[index] = array[rs];
index++;
rs++;
}
}
/* 第二次选择归并,将array中剩余的未加入temp的数加入到temp中 */
while (ls <= le) {
temp[index] = array[ls];
ls++;
index++;
}
while (rs <= re) {
temp[index] = array[rs];
rs++;
index++;
}
/* temp是经过调整后的array,此时一次归并完毕,返回数据进行下一次归并 */
while (leftStart <= rightEnd) {
array[leftStart] = temp[leftStart];
leftStart += 1;
}
/* 打印本次归并结果,输出成图像 */
m.updateShowArray(array);
} /* 打印数组 */
public static void printArray(int[] array) {
for (int i = 0; i < array.length; i++)
System.out.print(array[i] + " ");
System.out.println();
} } /* 工具类,获取当前屏幕大小,用户初始化显示组件和new乱序数组 */
class Tool {
public static int W = (int) Toolkit.getDefaultToolkit().getScreenSize()
.getWidth();/* 当前屏幕宽度 */
public static int H = (int) Toolkit.getDefaultToolkit().getScreenSize()
.getHeight();/* 当前屏幕高度 */
} /* 画图面板 */
class MyJPanel extends JPanel {
private static final long serialVersionUID = 1L;
int[] array;/* 用于接收构造方法传过来的数组,用于绘图 */ public MyJPanel(int[] a) {
array = a;
} /* 绘图函数 */
public void paintComponent(Graphics g) {
/* 画笔置白色 */
g.setColor(Color.WHITE);
/* 擦除上一次绘制的团 */
g.fillRect(0, 0, Tool.W, Tool.H);
/* 画笔置黑色 */
g.setColor(Color.black);
/* 开始绘制当前数组图像,以(0,Tool.H)为原点,向右为x轴表数组下标,向上为y轴表当前下标所对应数组存置大小 */
for (int i = 0; i < array.length; i++) {
g.drawLine(i, Tool.H - 80, i, Tool.H - array[i] - 80);
} }
} /* 显示主框架JFrame类 */
class updateShowArrayImg extends JFrame {
private static final long serialVersionUID = 1L;
MyJPanel show; /* 构造函数,初始化显示框架 */
public updateShowArrayImg(int[] a) {
show = new MyJPanel(a);
show.setBounds(0, 0, Tool.W, Tool.H);
this.setSize(Tool.W, Tool.H);
this.setTitle("归并排序");
this.setLocation(0, 0);
this.add(show);
this.setVisible(true);
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
} /**
* 更新画布
*
* @param a
*/
public void updateShowArray(int[] a) {
this.remove(show);
show = new MyJPanel(a);
this.add(show);
this.setVisible(true);
}
}

ShowMergeSort.java

  效果图奉上:

  优酷视频之GUI显示归并算法过程

【子非鱼】归并排序过程呈现之java内置GUI表示的更多相关文章

  1. 【开发者笔记】归并排序过程呈现之java内置GUI表示

    在网上看到一个视频将各种排序用视频表示出来,配上音乐,挺好玩的样子,就算是不会编程的人看到也会觉得很舒服,碰巧我也正在写归并算法,于是就用java的GUI实现一个. 归并排序的时间复杂度是T(n)=O ...

  2. 【子非鱼】冒泡排序过程呈现之java内置GUI表示

    自己玩玩写写,排序的过程多么有趣,特别是把看着电脑吧一堆乱七八糟的数据排成有序组合的时候,看起来贼舒服,特别是强迫症患者.好了,话不多说上代码,也算是自己记录一下吧,没有什么技术含量但个人感觉比较有趣 ...

  3. 【开发者笔记】冒泡排序过程呈现之java内置GUI表示

    自己玩玩写写,排序的过程多么有趣,特别是把看着电脑吧一堆乱七八糟的数据排成有序组合的时候,看起来贼舒服,特别是强迫症患者.好了,话不多说上代码,也算是自己记录一下吧,没有什么技术含量但个人感觉比较有趣 ...

  4. 【子非鱼】插入排序过程呈现之java内置GUI表示

    先给代码,再给过程视频: package com.dyi.wyb.sort; import java.awt.Color; import java.awt.Graphics; import java. ...

  5. 【开发者笔记】插入排序过程呈现之java内置GUI表示

    先给代码,再给过程视频: package com.dyi.wyb.sort; import java.awt.Color; import java.awt.Graphics; import java. ...

  6. Java 性能分析工具 , 第 2 部分:Java 内置监控工具

    引言 本文为 Java 性能分析工具系列文章第二篇,第一篇:操作系统工具.在本文中将介绍如何使用 Java 内置监控工具更加深入的了解 Java 应用程序和 JVM 本身.在 JDK 中有许多内置的工 ...

  7. 深入理解Java内置锁和显式锁

    synchronized and Reentrantlock 多线程编程中,当代码需要同步时我们会用到锁.Java为我们提供了内置锁(synchronized)和显式锁(ReentrantLock)两 ...

  8. 使用Java内置的Http Server构建Web应用

    一.概述 使用Java技术构建Web应用时, 我们通常离不开tomcat和jetty之类的servlet容器,这些Web服务器功能强大,性能强劲,深受欢迎,是运行大型Web应用的必备神器. 虽然Jav ...

  9. java内置线程池ThreadPoolExecutor源码学习记录

    背景 公司业务性能优化,使用java自带的Executors.newFixedThreadPool()方法生成线程池.但是其内部定义的LinkedBlockingQueue容量是Integer.MAX ...

随机推荐

  1. java原装代码完成pdf在线预览和pdf打印及下载

    这是我在工作中,遇到这样需求,完成需求后,总结的成果,就当做是工作笔记,以免日后忘记,当然,能帮助到别人是最好的啦! 下面进入正题: 前提准备: 1. 项目中至少需要引入的jar包,注意版本: a)  ...

  2. C++ cout 输出小数点后指定位数

    在C中我们可以使用 printf("%.2lf",a);但在C++中是没有格式操作符的,该如何操作: C++使用setprecision()函数,同时必须包含头文件iomanip, ...

  3. linux虚拟机CentOS 7完整安装流程截图

    安装VMware虚拟机过程此处省略,只介绍在虚拟机上安装linux系统CentOS 7过程截图. 1 新建虚拟机 2 命名虚拟机,选择linux安装位置 3 选择虚拟机处理器数量和处理器核心数 4 分 ...

  4. Hadoop1.0.3环境搭建流程

    0x00 大数据平台相关链接 官网:http://hadoop.apache.org/ 主要参考教程:http://www.cnblogs.com/xia520pi/archive/2012/05/1 ...

  5. Java String类练习题

    题目:1. 给定一个字符串,判断该字符串中是否包含某个子串.如果包含,求出子串的所有出现位置.如:"abcbcbabcb34bcbd"中,"bcb"子串的出现位 ...

  6. JavaScript实现按键精灵

    最近有个需求,需要在页面上面自动点击.输入.提交. 用以模拟真实用户的操作行为,可以通过直接执行某个元素绑定的事件,来执行操作. 也可以创建事件,再派发事件,执行操作.关于事件的更多细节,可以参考&l ...

  7. 第一次AOP,附上使用DEMO,目前只供学习,不可用在生产环境

    GIT代码地址:https://git.oschina.net/ruanjianfeng/Ruan.Framework.Core demo代码如下 public class ConsoleTimeAt ...

  8. Java Properties类源码分析

    一.Properties类介绍 java.util.Properties继承自java.util.Hashtable,从jdk1.1版本开始,Properties的实现基本上就没有什么大的变动.从ht ...

  9. laravel项目中手机浏览器在线阅读pdf文件-->PDFJS插件

    第一步:下载链接:http://mozilla.github.io/pdf.js/getting_started/#download 第二步:将下载的文件放在项目中. 第三步:在项目中想要预览的地方给 ...

  10. 使用SigbalR发送通知

    微信商城使用支付宝支付的时候,需要有个过度页面提示用户用浏览器打开页面去支付,等用户在浏览器支付完之后再打开微信(微信此时依旧显示的是过度页面),过度页面需要跳转到订单详情页面.那么这个过度页面怎么知 ...