2010-12-06 03:21:09 +00:00
|
|
|
/* Copyright (c) 2008-2010, Avian Contributors
|
2008-02-19 18:06:52 +00:00
|
|
|
|
|
|
|
Permission to use, copy, modify, and/or distribute this software
|
|
|
|
for any purpose with or without fee is hereby granted, provided
|
|
|
|
that the above copyright notice and this permission notice appear
|
|
|
|
in all copies.
|
|
|
|
|
|
|
|
There is NO WARRANTY for this software. See license.txt for
|
|
|
|
details. */
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
package java.util;
|
|
|
|
|
|
|
|
public class Arrays {
|
|
|
|
private Arrays() { }
|
|
|
|
|
2007-08-24 01:57:42 +00:00
|
|
|
public static String toString(Object[] a) {
|
|
|
|
return asList(a).toString();
|
|
|
|
}
|
|
|
|
|
2012-08-04 22:08:32 +00:00
|
|
|
public static String toString(byte[] a) {
|
|
|
|
if (a == null) {
|
|
|
|
return "null";
|
|
|
|
} else {
|
|
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.append("[");
|
|
|
|
for (int i = 0; i < a.length; ++i) {
|
|
|
|
sb.append(String.valueOf(a[i]));
|
|
|
|
if (i + 1 != a.length) {
|
|
|
|
sb.append(", ");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
sb.append("]");
|
|
|
|
return sb.toString();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-07-22 19:06:21 +00:00
|
|
|
private static boolean equal(Object a, Object b) {
|
|
|
|
return (a == null && b == null) || (a != null && a.equals(b));
|
|
|
|
}
|
|
|
|
|
2008-02-28 18:37:10 +00:00
|
|
|
public static void sort(Object[] array) {
|
|
|
|
sort(array, new Comparator() {
|
|
|
|
public int compare(Object a, Object b) {
|
|
|
|
return ((Comparable) a).compareTo(b);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2007-12-03 23:32:54 +00: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;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-07-24 16:03:19 +00:00
|
|
|
public static int hashCode(Object[] array) {
|
2012-07-24 17:31:47 +00:00
|
|
|
if(array == null) {
|
|
|
|
return 9023;
|
|
|
|
}
|
|
|
|
|
2012-07-23 13:28:05 +00:00
|
|
|
int hc = 823347;
|
2012-07-24 16:03:19 +00:00
|
|
|
for(Object o : array) {
|
2012-07-24 17:31:47 +00:00
|
|
|
hc += o != null ? o.hashCode() : 54267;
|
2012-07-23 13:28:05 +00:00
|
|
|
hc *= 3;
|
|
|
|
}
|
|
|
|
return hc;
|
|
|
|
}
|
|
|
|
|
2012-07-24 16:03:19 +00:00
|
|
|
public static boolean equals(Object[] a, Object[] b) {
|
2012-07-24 17:31:47 +00:00
|
|
|
if(a == b) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if(a == null || b == null) {
|
|
|
|
return false;
|
|
|
|
}
|
2012-07-23 13:28:05 +00:00
|
|
|
if(a.length != b.length) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
for(int i = 0; i < a.length; i++) {
|
2012-07-24 16:03:19 +00:00
|
|
|
if(!equal(a[i], b[i])) {
|
2012-07-23 13:28:05 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
public static <T> List<T> asList(final T ... array) {
|
|
|
|
return new List<T>() {
|
2007-08-24 01:57:42 +00:00
|
|
|
public String toString() {
|
|
|
|
return Collections.toString(this);
|
|
|
|
}
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
public int size() {
|
|
|
|
return array.length;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean add(T element) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2008-02-28 18:37:10 +00:00
|
|
|
public boolean addAll(Collection<? extends T> collection) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2007-09-26 16:32:39 +00:00
|
|
|
public void add(int index, T element) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2009-04-22 21:24:26 +00:00
|
|
|
public boolean contains(Object element) {
|
2007-07-22 19:06:21 +00:00
|
|
|
for (int i = 0; i < array.length; ++i) {
|
|
|
|
if (equal(element, array[i])) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2009-08-04 23:58:31 +00:00
|
|
|
public int indexOf(Object element) {
|
|
|
|
for (int i = 0; i < array.length; ++i) {
|
|
|
|
if (equal(element, array[i])) {
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int lastIndexOf(Object element) {
|
|
|
|
for (int i = array.length - 1; i >= 0; --i) {
|
|
|
|
if (equal(element, array[i])) {
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
public T get(int index) {
|
|
|
|
return array[index];
|
|
|
|
}
|
|
|
|
|
2007-11-14 16:32:36 +00:00
|
|
|
public T set(int index, T value) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2009-08-04 23:36:25 +00:00
|
|
|
public Object[] toArray() {
|
|
|
|
return toArray(new Object[size()]);
|
|
|
|
}
|
|
|
|
|
2007-09-26 14:57:34 +00:00
|
|
|
public <S> S[] toArray(S[] a) {
|
|
|
|
return (S[])array;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isEmpty() {
|
|
|
|
return size() == 0;
|
|
|
|
}
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
public T remove(int index) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2009-04-22 21:24:26 +00:00
|
|
|
public boolean remove(Object element) {
|
2007-07-22 03:47:29 +00:00
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
|
|
|
public void clear() {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
|
|
|
public Iterator<T> iterator() {
|
2009-08-04 23:24:29 +00:00
|
|
|
return listIterator();
|
|
|
|
}
|
|
|
|
|
|
|
|
public ListIterator<T> listIterator(int index) {
|
|
|
|
return new Collections.ArrayListIterator(this, index);
|
|
|
|
}
|
|
|
|
|
|
|
|
public ListIterator<T> listIterator() {
|
|
|
|
return listIterator(0);
|
2007-07-22 03:47:29 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
2008-07-14 00:28:27 +00:00
|
|
|
|
|
|
|
public static void fill(int[] array, int value) {
|
|
|
|
for (int i=0;i<array.length;i++) {
|
|
|
|
array[i] = value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void fill(char[] array, char value) {
|
|
|
|
for (int i=0;i<array.length;i++) {
|
|
|
|
array[i] = value;
|
|
|
|
}
|
|
|
|
}
|
2010-08-15 12:01:33 +00:00
|
|
|
|
|
|
|
public static <T> void fill(T[] array, T value) {
|
|
|
|
for (int i=0;i<array.length;i++) {
|
|
|
|
array[i] = value;
|
|
|
|
}
|
|
|
|
}
|
2008-07-14 00:28:27 +00:00
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
}
|