Hark的数据结构与算法练习之Bogo排序
2024-10-14 18:00:01
算法说明
Bogo排序是交换排序的一种,它是一种随机排序,也是一种没有使用意义的排序,同样也是一种我觉得很好玩的排序。
举个形象的例子,你手头有一副乱序的扑克牌,然后往天上不停的扔,那么有一定机率会变成有序的。
哈哈,就是这样。
看一下代码大家就知道了。
代码
使用的是java
package hark.sort.exchangesort; import java.util.Random; /*
* Bogo排序
*/
public class BogoSort {
public static void main(String[] args) {
int[] arrayData = { 2, 4, 8, 9, 1 };
BogoSortMethod(arrayData);
for (int integer : arrayData) {
System.out.print(integer);
System.out.print(" ");
}
} public static void BogoSortMethod(int[] arrayData) {
while (!WhetherSort(arrayData)) {
Sort(arrayData);
}
} static Random random = new Random();
static int temp,swapIndex; public static void Sort(int[] arrayData) {
for (int i = 0; i < arrayData.length; i++) {
swapIndex = random.nextInt(i + 1);
temp = arrayData[i];
arrayData[i]= arrayData[swapIndex];
arrayData[swapIndex] = temp;
}
} public static boolean WhetherSort(int[] arrayData) {
for(int i = 0;i<arrayData.length-1;i++)
{
if(arrayData[i]> arrayData[i+1])
{
return false;
}
}
return true;
}
}
参考
http://zh.wikipedia.org/zh-cn/%E6%8E%92%E5%BA%8F%E7%AE%97%E6%B3%95
最新文章
- matlab 曲线拟合
- Daily Scrum 12.14
- 各种排序算法的分析及java实现
- Swift3.0P1 语法指南——字符串与字符
- 【knowledgebase】不要在一个很大的RDD上调用collect
- ylbtech-Bill(发票管理)-数据库设计
- DelphiXE Android的所有权限按照分类总结说明
- &;&;与&;
- [转]操作xml,将xml数据显示到treeview的C#代码
- 解决Ubuntu 16.04 软件中心闪退
- 分享一个 jmeter ant的build.xml
- nodejs辅助前台开发系列(1) 搭建简单HTML开发环境
- MySQL5.7.21解压版安装详细教程以及一些问题的解决
- java Comparable and Comparator
- 朱晔和你聊Spring系列S1E10:强大且复杂的Spring Security(含OAuth2三角色+三模式完整例子)
- 本地项目提交到github和提交更新(转)
- 【工具相关】Web-Sublime Text2-注释
- Service 动态更新 UI
- AVL树原理及实现 +B树
- Android——Fragment+Editext总结