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);
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Is Eclipse IDE dying?In 2014 the Eclipse IDE is the leading development environment for Java with a market share of approximately 65%. but ac...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.