数组操作增,删,改,查

 

增加数组元素:即向数组中插入一个新元素值

操作过程:

        1)新建一个比原来数组长度大1的数组;

        2)将原来数组里的元素按照顺序依次存储到新的数组中

        3)输入要增加的元素值,以及插入的位置(即数组下标)

        4)从插入位置开始及之后的元素依次往后移动一位(注意:移动的时候,从后向前移动)

        5)移动元素之后,插入位置就空出来了,将插入元素存储到插入位置


		/* 有一组学员的成绩{99,85,82,63, 60}。要增加一个学员的成绩,将它插 
         *   入成绩序列
		 *
         *思路: 
		 * 1)新建一个比原来数组长度大1的数组 
		 * 2)将原来数组里的元素按照顺序存储到新的数组中
		 * 3)使用Scanner获取你要增加的学员成绩,以及插入的位置(下标)
		 * 4)从插入位置开始及之后的元素依次往后移动一位(注意:移动的时候,从后向前移动)
		 * 5)移动元素之后,插入位置就空出来了,将插入元素存储到插入位置
		 */

        int[] scores={99,85,82,63,60};
		
		// 1)新建一个比原来数组长度大1的数组
		int[] newScores= new int[scores.length+1];
		
		// 2)将原来数组里的元素按照顺序存储到新的数组中
		for (int i = 0; i < scores.length; i++) {
			newScores[i]=scores[i];
		}
		
		//3)使用Scanner获取你要增加的学员成绩
		Scanner sc =new Scanner(System.in);
		System.out.println("请输入插入的数字:");
		int insert =sc.nextInt();
        //在数组第一个位置插入新同学的成绩
        int index=0;
        
        //4)从插入位置开始及之后的元素依次往后移动一位(注意:移动的时候,从后向前移动)
		for(int i=newScores.length-1;i>index;i--){
			newScores[i]=newScores[i-1];
		}
		
		//5)移动元素之后,插入位置就空出来了,将插入元素存储到插入位置
		newScores[index]=insert;
		
		//插入元素之后,遍历数组
		for (int i = 0; i < newScores.length; i++) {
			System.out.print(newScores[i]+" ");
		}

 

删除数组元素

        操作过程:

                1)确定删除需要删除元素的指定位置(即下标)

                2)从删除位置之后的元素依次往前移动一位

                3)最后一位元素值赋予对应类型的初始值

        //删除数组里的元素
		int[] nums={11,25,96,65,49,78,95};
		System.out.println("删除元素之前的数组:");
		for (int i = 0; i < nums.length; i++) {
			System.out.print(nums[i]+" ");			
		}
		System.out.println();
		
		//删除指定位置的元素
		Scanner sc =new Scanner(System.in);
		System.out.println("请输入你要删除的元素位置(下标)(0-6)");
		int index=sc.nextInt();
		
		//从删除位置之后的元素依次往前移动一位
		for (int i = index; i < nums.length-1; i++) {
			nums[i]=nums[i+1];			
		}
		
		//最后一位元素值赋予对应类型的初始值
		if(index>=0&&index<7){
			nums[nums.length-1]=0;		
		}
		
		System.out.println("删除元素之后的数组:");
		for (int i = 0; i < nums.length; i++) {
			System.out.print(nums[i]+" ");			
		}

 

 

 改变数组元素的值

        操作过程:

                数组名 [下标] = 修改的值;

查找数组元素:

        操作过程:

                查找数组单个元素:

               System.out.println(数组名 [下标] = 修改的值) ;

                查找数组所有元素(即遍历):
    普通for循环
        for(int i =0;i<数组名.length;i++){
            System.out.println(数组名[i]);
        }
    增强for循环
        for(数据类型 变量名 : 数组名){
            System.out.println(变量名);
        }

 

        int[] nums={25,31,98,15,47,34,75,84,65,61,72,86,15,45,79,94,31,57};
		
		//获取数组中元素的个数:数组名.length
		int size=nums.length;
		System.out.println("nums数组中元素的个数是:"+size);
		
		//遍历:按照元素在数组中的顺序输出
		for (int i = 0; i < nums.length; i++) {
			System.out.print(nums[i]+" ");
		}
		
		System.out.println();
		
		//遍历还可以使用增强for循环来进行遍历
		
		/*
		 * for(数据类型 变量名:数组名){
		 * }
		 * 
		 * 执行规律:按照数组中元素的顺序依次将元素取出来存入到变量a中,
		 * 这时候操作变量a就相当于操作数组里的元素
		 */
		for(int a:nums){
			System.out.print(a+" ");
		}

 

 

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值