import java.util.Arrays;
public class Demo {
public static void main(String[] args) {
int[] arr = { 2, 1, 3, 1, 1, 4, 6, 4, 5, 8, 6, 2, 9, 8, 7, 7 };
arr = f(arr, 1);
System.out.println(Arrays.toString(arr));
}
// 发现重复的元素就从这个元素索引开始 把数组中元素依次向前移动一位 然后把数组长度减一
public static int[] f(int[] arr, int index) {
if (index < arr.length) {
boolean flag = false;
for (int i = index - 1; i >= 0; i--) {
if (arr[index] == arr[i]) {
for (int k = index; k < arr.length - 1; k++) {
arr[k] = arr[k + 1];
}
arr = Arrays.copyOf(arr, arr.length - 1);
flag = true;
break;
}
}
index = flag ? index : index + 1;
return f(arr, index);
} else {
return arr;
}
}
}
|