大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
思路
1. 因为数组长度在初始化的时候是指定的并且不可变的,所以不能在原有的数组上直接进行删除操作,需要新建一个长度为当前长度减1的数组
2. 向新数组写数据
/**
* remove element at the specified position from the given array by loop
*
* @param array
* @param position
* @return
*/
public static String[] removeElementByLoop(String[] array, int position) {
if (position < 0 || position > array.length) {
throw new IndexOutOfBoundsException("the position is out of the array indices");
}
long startTime = System.currentTimeMillis();
String[] newArray = new String[array.length - 1];
int index = position - 1;
for (int i = 0; i < array.length; i++) {
if (i < index) {
newArray[i] = array[i];
} else if (i > index) {
newArray[i - 1] = array[i];
}
}
System.out.println("took:" + (System.currentTimeMillis() - startTime) + " ms by loop solution");
return newArray;
}
/**
* remove element at the specified position from the given array by copy
*
* @param array
* @param position
* @return
*/
public static String[] removeElementByCopy(String[] array, int position) {
int length = array.length;
if (position < 0 || position > length) {
throw new IndexOutOfBoundsException("the position is out of the array indices");
}
long startTime = System.currentTimeMillis();
String[] newArray = new String[array.length - 1];
int index = position - 1;
System.arraycopy(array, 0, newArray, 0, index);
if (index < length - 1) {
System.arraycopy(array, index + 1, newArray, index, length - index - 1);
}
System.out.println("took:" + (System.currentTimeMillis() - startTime) + " ms by copy solution");
return newArray;
}
对比:
从时间复杂度来说removeElementByCopy的性能能优于removeElementByLoop,因为removeElementByLoop是0(n)而removeElementByCopy是0(1)。
从空间复杂度来说removeElementByLoop的性能能优于removeElementByCopy,因为removeElementByCopy需要更多次的swap。
下面是测试结果
1. 当原数组长度较少的时候.
List<String> elements = new ArrayList<String>();
for (int i = 0; i < 90000; i++) {
elements.add(i + "");
}
String[] array = elements.toArray(new String[elements.size()]);
int position = 80000;
removeElementByCopy(array, position);
removeElementByLoop(array, position);
—->
took:0 ms by copy solution
took:2 ms by loop solution
2.
List<String> elements = new ArrayList<String>();
for (int i = 0; i < 1000000; i++) {
elements.add(i + "");
}
String[] array = elements.toArray(new String[elements.size()]);
int position = 80000;
removeElementByCopy(array, position);
removeElementByLoop(array, position);
—->
took:7 ms by copy solution
took:88 ms by loop solution
从测试结果可以看出来,在执行时间上的花费,removeElementByCopy的效率明显高于removeElementByLoop
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/169495.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...