java实现归并排序,树形排序(锦标赛制);java字符串分隔或的形式
来源:互联网 发布:淘宝开个人食品店 编辑:程序博客网 时间:2024/06/08 13:58
String[] b=str.split("query|,");//query分隔或者逗号分隔
归并排序,递归实现
public class MergeSort2 {// 对data数组中的 [a,b) 区间的数据进行归并排序,
// 排序结束后,[a,b)间数据处于升序有序状态
static void mergeSort(int[] data, int a,int b)
{
if (a >= b) return;
int mid=(a+b)/2;//拆分排序
mergeSort(data,a,mid);
mergeSort(data,mid+1,b);
//前面两个拍好了或者只有个一个元素时执行下面
merge(data,a,mid,b);}
// data中的数据, [low,mid), [mid,high) 是两段待归并数据。归并后,[low,high) 整体有序
static void merge(int[] data, int low,int mid,int high)
{
int[] tmp = new int[high-low+1];
int[] a=new int[mid-low+1];
int[] b=new int[high-mid];
//给两半数组赋值
for (int i = 0; i < a.length; i++) {a[i]=data[low+i-1];
}
for (int i = 0; i < b.length; i++) {
b[i]=data[mid+i];
}
int ai=0;//只要能表达其位置的都可以称为指针,不一定是指向内存地址,C可能是指向内存地址
int bi=0;
int ci=0;
while (ai<a.length&&bi<high-mid) {
//谁小就先添加谁
if (a[ai]<=b[bi]) {
tmp[ci++]=a[ai++];
}
else {
tmp[ci++]=b[bi++];
}
}
//判断剩余,将剩余的添加到尾部
while (ai<a.length)tmp[ci++]=a[ai++];
while (bi<b.length)tmp[ci++]=b[bi++];
//把排好的值赋给数组
int i=0;int k=low-i-1;
while (i<ci) {data[k++]=tmp[i++];
}
}
//上面的操作针对数组,所以数组发生了变化,若是变量,只是在方法中改变值,出了方法值不变,除非设成引用类型
public static void main(String[] args) {
int[] a = { 26, 29, 60, 60, 11, 15, 20, 75, 100, 500, 1000, 3, 5, 6, 8,9 };
//int[] a={3,2,1};
mergeSort(a, 1,a.length);
for (int i = 0; i < a.length; i++) {
System.out.print(a[i]+" ");
}
}
}
树形排序
public class TreeSort {
public static int[] treeAgain(int[] a) {
// 树排序挺浪费空间的,数值16个,排序完全二叉树,需要31个节点
int[] allCode = new int[2 * a.length - 1];
for (int i = allCode.length - 1; i >= 0; i--) {
if (i - a.length + 1 >= 0) {
allCode[i] = a[i - a.length + 1];
} else {
if (allCode[i * 2 + 1] <= allCode[i * 2 + 2]) {
allCode[i] = allCode[i * 2 + 1];
} else {
allCode[i] = allCode[i * 2 + 2];
}
}
}
return allCode;
}
public static void treeSort(int[] a) {
int allCode[] = null;
while (true) {
//重新赋值后再排序
allCode = treeAgain(a);
if (allCode[0]==Integer.MAX_VALUE) {
break;
}
System.out.print(allCode[0] + " ");
for (int i = 0; i < a.length; i++) {
if (a[i] == allCode[0]) {
a[i] = Integer.MAX_VALUE;
}
}
}
//树形显示
/*
* int n = 1;
*
* for (int i = 0; i < allCode.length; i++) {
* System.out.print(allCode[i] + " ");
*
* int x = (int) Math.pow(2, n) - 2; if (i == x) { System.out.println();
* n++; }
*
* }
*/
}
/**
* @param args
*/
public static void main(String[] args) {
int[] a = { 26, 29, 60, 60, 11, 15, 20, 75, 100, 500, 1000, 3, 5, 6, 8,
9 };
treeSort(a);
}
}
- java实现归并排序,树形排序(锦标赛制);java字符串分隔或的形式
- java实现的归并排序
- 归并排序的java实现
- 归并排序的Java实现
- 归并排序的java实现
- 归并排序的java实现
- 归并排序的java实现
- 归并排序的java实现
- Java实现的归并排序
- Java归并排序的实现
- 归并排序的Java实现
- [排序算法]--归并排序的Java实现
- 排序算法的java实现-归并排序
- 归并排序(java实现)
- 归并排序(java实现)
- 归并排序(Java实现)
- 归并排序实现(Java)
- 归并排序(java实现)
- 创新实验室实习生每周工作总结【实习第三周】
- 文件系统
- sshd系统自带启动脚本详解
- mysql分表的3种方法
- 如何基于微信开放接口开发企业的微信CRM
- java实现归并排序,树形排序(锦标赛制);java字符串分隔或的形式
- Android开发必备的21个免费资源和工具
- C++中内存存储
- 完全数
- 二叉查找树的操作
- Hibernate问题记录
- 算法学习十五----找数组最大值和最小值
- 想出好创意 做出好产品 成为好的创业者
- Go语言 unsafe的妙用