数组删除元素

数组删除元素

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");
        }
    }
}

输出:

相关推荐
救救孩子把6 分钟前
深入理解 Java 对象的内存布局
java
落落落sss9 分钟前
MybatisPlus
android·java·开发语言·spring·tomcat·rabbitmq·mybatis
万物皆字节14 分钟前
maven指定模块快速打包idea插件Quick Maven Package
java
夜雨翦春韭21 分钟前
【代码随想录Day30】贪心算法Part04
java·数据结构·算法·leetcode·贪心算法
简单.is.good26 分钟前
【测试】接口测试与接口自动化
开发语言·python
我行我素,向往自由27 分钟前
速成java记录(上)
java·速成
一直学习永不止步33 分钟前
LeetCode题练习与总结:H 指数--274
java·数据结构·算法·leetcode·数组·排序·计数排序
邵泽明34 分钟前
面试知识储备-多线程
java·面试·职场和发展
Yvemil71 小时前
MQ 架构设计原理与消息中间件详解(二)
开发语言·后端·ruby
程序员是干活的1 小时前
私家车开车回家过节会发生什么事情
java·开发语言·软件构建·1024程序员节