2007-07-21 21:47:29 -06:00
|
|
|
package java.util;
|
|
|
|
|
|
|
|
public class Arrays {
|
|
|
|
private Arrays() { }
|
|
|
|
|
2007-08-23 19:57:42 -06:00
|
|
|
public static String toString(Object[] a) {
|
|
|
|
return asList(a).toString();
|
|
|
|
}
|
|
|
|
|
2007-07-22 13:06:21 -06:00
|
|
|
private static boolean equal(Object a, Object b) {
|
|
|
|
return (a == null && b == null) || (a != null && a.equals(b));
|
|
|
|
}
|
|
|
|
|
2007-12-03 16:32:54 -07:00
|
|
|
public static <T> void sort(T[] array, Comparator<? super T> comparator) {
|
|
|
|
// insertion sort
|
|
|
|
for (int j = 1; j < array.length; ++j) {
|
|
|
|
T t = array[j];
|
|
|
|
int i = j - 1;
|
|
|
|
while (i >= 0 && comparator.compare(array[i], t) > 0) {
|
|
|
|
array[i + 1] = array[i];
|
|
|
|
i = i - 1;
|
|
|
|
}
|
|
|
|
array[i + 1] = t;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-07-21 21:47:29 -06:00
|
|
|
public static <T> List<T> asList(final T ... array) {
|
|
|
|
return new List<T>() {
|
2007-08-23 19:57:42 -06:00
|
|
|
public String toString() {
|
|
|
|
return Collections.toString(this);
|
|
|
|
}
|
|
|
|
|
2007-07-21 21:47:29 -06:00
|
|
|
public int size() {
|
|
|
|
return array.length;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean add(T element) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2007-09-26 10:32:39 -06:00
|
|
|
public void add(int index, T element) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2007-07-22 13:06:21 -06:00
|
|
|
public boolean contains(T element) {
|
|
|
|
for (int i = 0; i < array.length; ++i) {
|
|
|
|
if (equal(element, array[i])) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2007-07-21 21:47:29 -06:00
|
|
|
public T get(int index) {
|
|
|
|
return array[index];
|
|
|
|
}
|
|
|
|
|
2007-11-14 09:32:36 -07:00
|
|
|
public T set(int index, T value) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2007-09-26 08:57:34 -06:00
|
|
|
public <S> S[] toArray(S[] a) {
|
|
|
|
return (S[])array;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isEmpty() {
|
|
|
|
return size() == 0;
|
|
|
|
}
|
|
|
|
|
2007-07-21 21:47:29 -06:00
|
|
|
public T remove(int index) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean remove(T element) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
|
|
|
public void clear() {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
|
|
|
public Iterator<T> iterator() {
|
|
|
|
return new Collections.ArrayListIterator(this);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|