放置了一些排序使用的子函数
/**
* Util.java
*
* 工具类
*
* @author Administrator
*/
public class Util {
/**
* 对换数组a两个下标i和j对应的值.
*
* @param a
* @param i
* @param j
*/
public static void swap(int[] a, int i, int j) {
int temp = a[i];
a[i] = a[j];
a[j] = temp;
}
/**
* 合并数组元素c[l:m]和c[m+1:r]至d[l:r]中.
* 前提:c[l:m]和c[m+1:r]必须是有序的
*
* @param c
* @param d
* @param l
* @param m
* @param r
*/
public static void merge(int[] c, int[] d, int l, int m, int r) {
int i = l,
j = m + 1,
k = l;
while ((i <= m) && (j <= r))
if (c[i] <= c[j])
d[k++] = c[i++];
else
d[k++] = c[j++];
if (i > m)
for (int q = j; q <= r; q++)
d[k++] = c[q];
else
for (int q = i; q <= m; q++)
d[k++] = c[q];
}
/**
* 把数组元素 b[left:right] 复制到 a[left:right]
* 前提假设:a,b数组必须等长.
*
* @param a
* @param b
* @param left
* @param right
*/
public static void copy(int[] a, int[] b, int left, int right){
for(int i = left; i <= right; i ++)
a[i] = b[i];
}
/**
* 合并数组x中大小为s的相邻元素到数组y.
*
* 前提:x,y数组长度相等.
*
* @param x
* @param y
* @param s
*/
public static void mergePass(int[] x, int[] y, int s) {
int i = 0;
int n = x.length;
while( n - 2 * s > i) {
Util.merge(x, y, i, i + s - 1, i + 2 * s - 1);
i += 2*s;
}
//剩下的元素个数小于2s
//元素个数小于2s大于s个
if(n - i > s)
Util.merge(x, y, i, i + s - 1, n-1);
//元素个数小于s个
else for(int j = i; j <= n-1; j ++)
y[j] = x[j];
}
public static void main(String[] args){
/*int[] c = new int[]{0,2,3,1};
int[] d = new int[c.length];
merge(c,d,0,2,3);
for(int i=0; i<c.length; i++)
System.out.println(d[i]);
*/
System.out.println(1/32);
}
}
分享到:
相关推荐
<Call Stack = DEBUG_FRAME = org.apache.axis2.util.JavaUtils.callStackToString(JavaUtils.java:564) DEBUG_FRAME = org.apache.axis2.description.ParameterIncludeImpl.debugParameterAdd(ParameterIncludeImpl...
在开发基于Axis2的Web服务时,可能会遇到各种错误和异常,其中之一就是与`org.apache.axis2.util.JavaUtils.callStackToString`相关的问题。这个问题通常出现在Axis2尝试获取并打印堆栈跟踪信息时。 `...
MD5Util.java
java常用工具类,用于日常开发的。
StringUtil工具类java学习的好东西!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!...
java编程中对字符串的各种方式的处理,包括(空字符串处理、判断是否是空字符串 null和"" 都返回 true、 把string array or list用给定的符号symbol连接成一个字符串、 判定第一个字符串是否等于的第二个字符串中的某...
在IT领域,尤其是在Java开发中,`Util.java`类扮演着关键角色,它封装了一系列公共方法,用于简化日常编程任务,提高代码复用性。从给定的文件信息来看,`Util.java`主要关注以下几个方面的功能:日期时间处理、字符...
构造一个http 请求的主体类,然后通过该类在java中模拟http请求
Md5Util.java
Word2007Util.java.rar
JacksonUtil.java
在使用spring mvc 使用反射自动生成对象 的代码 方便使用
Base64Util.java
自定义依赖注入工具类SpringUtil.java
SHA256Util.java,哈希编码工具类