在Java中,如果你想要将数组中的素向后移动,你可以使用以下几种方法:
1. 使用循环和数组复制:
java
public class ArrayShift {
public static void main(String[] args) {
int[] array = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
int n = array.length;
int m = 3; // 向后移动的位置数
// 创建一个新数组,长度为原数组长度减去移动的位置数
int[] newArray = new int[n - m];
// 将原数组中除了最后m个素之外的所有素复制到新数组中
System.arraycopy(array, m, newArray, 0, n - m);
// 输出移动后的数组
for (int i = 0; i < newArray.length; i++) {
System.out.print(newArray[i] + " ");
}
}
}
2. 使用`ArrayList`的`add`方法:
java
import java.util.ArrayList;
public class ArrayListShift {
public static void main(String[] args) {
ArrayList
arrayList.add(1);
arrayList.add(2);
arrayList.add(3);
arrayList.add(4);
arrayList.add(5);
arrayList.add(6);
arrayList.add(7);
arrayList.add(8);
arrayList.add(9);
arrayList.add(10);
int m = 3; // 向后移动的位置数
// 在指定位置插入一个空素,然后将后面的素向前移动一位
arrayList.add(m, null);
// 删除原来的最后一个素
arrayList.remove(arrayList.size() - 1);
// 输出移动后的ArrayList
for (int i = 0; i < arrayList.size(); i++) {
System.out.print(arrayList.get(i) + " ");
}
}
}
3. 使用`System.arraycopy`方法:
java
public class ArrayCopyShift {
public static void main(String[] args) {
int[] array = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
int n = array.length;
int m = 3; // 向后移动的位置数
// 创建一个新数组,长度为原数组长度减去移动的位置数
int[] newArray = new int[n - m];
// 将原数组中除了最后m个素之外的所有素复制到新数组中
System.arraycopy(array, m, newArray, 0, n - m);
// 输出移动后的数组
for (int i = 0; i < newArray.length; i++) {
System.out.print(newArray[i] + " ");
}
}
}
以上代码展示了如何使用不同方法在Java中移动数组素。你可以根据你的具体需求选择合适的方法。需要注意的是,当移动素时,确保不会超出数组的长度,避免`ArrayIndexOutOfBoundsException`异常。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://sigusoft.com/bj/44357.html