Util.java

放置了一些排序使用的子函数


/**
* 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);
}

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值