数组删除元素

数组删除元素

1.利用新的数组

将原数组arr的元素,复制到新数组newArr中,复制过程中将要删除的元素,选择不复制

java 复制代码
public class Test01{
    public static void main(String [] args){
        String [] arr= {"zhangsan","lisi","wangmazi","tangliang"};

        //创建一个新的数组,长度设置为原数组-n,这里我们删除1个元素lisi ,所以长度设置为arr.length-1
       String [] newArr = new String[arr.length-1];


        int index = 0;  //设置一个索引值
        for(String name : arr){ //遍历arr数组
            if(!name.equals("lisi")){ //只要不是我们要删除的元素,
                newArr[index++] = name; //就复制给newArr的当前index ,然后index++
            }
        }


        arr = newArr; //将newArr的地址传递给arr

        //打印arr数组

        for(String str : arr){
            System.out.println(str);
        }
    }
}

输出:

缺点:数组作为容器,是存储数据的,这样的删除会让容器越变越小

2.利用数组元素往前移动

将要删除元素后面的元素全部往前移动,然后将最后以为赋值为null,这样数组的长度也不会变小

java 复制代码
public class Test01{
    public static void main(String [] args){
        String [] arr= {"zhangsan","lisi","wangmazi","tangliang"};

       //遍历数组
         int num = 0 ;  
        for(int i =0 ;i<arr.length;i++){
            if (arr[i].equals("lisi")){
                 num = i;   //获取要删除元素的下标
            }
        }
        //从要删除元素小表开始,后面的元素全部往前移动
        for(int i = num ; i<arr.length-1;i++){  //注意这里只遍历到倒数第二个元素,因为倒数第二个将倒数第一个往前移动后,倒数第一个找不到下一个元素
            arr[i] = arr[i+1];
        }
        arr[arr.length-1] = null; //将数组最后一个元素设置为null

        for(String name : arr){
            System.out.print(name+"\t");
        }
    }
}

输出:

相关推荐
雨中飘荡的记忆19 小时前
ElasticJob分布式调度从入门到实战
java·后端
考虑考虑1 天前
JDK25模块导入声明
java·后端·java ee
_小马快跑_1 天前
Java 的 8 大基本数据类型:为何是不可或缺的设计?
java
Re_zero1 天前
线上日志被清空?这段仅10行的 IO 代码里竟然藏着3个毒瘤
java·后端
洋洋技术笔记1 天前
Spring Boot条件注解详解
java·spring boot
程序员清风2 天前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
皮皮林5512 天前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
华仔啊2 天前
挖到了 1 个 Java 小特性:var,用完就回不去了
java·后端
SimonKing2 天前
SpringBoot整合秘笈:让Mybatis用上Calcite,实现统一SQL查询
java·后端·程序员
日月云棠3 天前
各版本JDK对比:JDK 25 特性详解
java