程序员最近都爱上了这个网站  程序员们快来瞅瞅吧!  it98k网:it98k.com

本站消息

站长简介/公众号

  出租广告位,需要合作请联系站长


+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

Java之数组扩容

发布于2021-05-29 19:29     阅读(795)     评论(0)     点赞(4)     收藏(4)


数组添加/扩容

  • 要求:实现动态的给数组添加元素效果,实现对数组扩容。ArrayAdd.java
  1. 原始数组使用静态分配 int[] arr = {1,2,3}
  2. 增加的元素 4,直接放在数组的最后 arr = {1,2,3,4}
    ArrayAdd02.java
  • 思路分析
    1. 定义初始数组 int[] arr = {1,2,3}//下标0-2
    2. 定义一个新的数组 int[] arrNew = new int[arr.length+1];
    3. 遍历 arr 数组,依次将arr的元素拷贝到 arrNew数组
    4. 将 4 赋给 arrNew[arrNew.length - 1] = 4;4赋给arrNew最后一个元素
    5. 让 arr 指向 arrNew ; arr = arrNew; 那么 原来arr数组就被销毁
  • 代码实现:
	  int[] arr = {1,2,3};
      int[] arrNew = new int[arr.length + 1];
      //遍历 arr 数组,依次将arr的元素拷贝到 arrNew数组
      for(int i = 0; i < arr.length; i++) {
          arrNew[i] = arr[i];
      }
      //把4赋给arrNew最后一个元素
      arrNew[arrNew.length - 1] = 4;
      //让 arr 指向 arrNew,
      arr = arrNew;
      //输出arr 看看效果
      System.out.println("====arr扩容后元素情况====");
      for(int i = 0; i < arr.length; i++) {
          System.out.print(arr[i] + "\t");
      }

在这里插入图片描述
在这里插入图片描述

  1. 用户可以通过如下方法来决定是否继续添加,添加成功,是否继续?y/n
  1. 创建一个 Scanner可以接受用户输入
  2. 因为用户什么时候退出,不确定,使用 do-while + break来控制

代码实现:

	Scanner myScanner = new Scanner(System.in);
	//初始化数组
	int[] arr = {1,2,3};
	
	do {
		int[] arrNew = new int[arr.length + 1];
		//遍历 arr 数组,依次将arr的元素拷贝到 arrNew数组
		for(int i = 0; i < arr.length; i++) {
			arrNew[i] = arr[i];
		}
		System.out.println("请输入你要添加的元素");
		int addNum = myScanner.nextInt();
		//把addNum赋给arrNew最后一个元素
		arrNew[arrNew.length - 1] = addNum;
		//让 arr 指向 arrNew, 
		arr = arrNew;
		//输出arr 看看效果
		System.out.println("====arr扩容后元素情况====");
		for(int i = 0; i < arr.length; i++) {
			System.out.print(arr[i] + "\t");
		}
		//问用户是否继续
		System.out.println("是否继续添加 y/n");
		char key = myScanner.next().charAt(0);
		if( key == 'n') { //如果输入n ,就结束
			break;
		}			
	}while(true);
	
	System.out.println("你退出了添加...");

在这里插入图片描述

原文链接:https://blog.csdn.net/qq_41684621/article/details/117332064



所属网站分类: 技术文章 > 博客

作者:怎么没有鱼儿上钩呢

链接:http://www.javaheidong.com/blog/article/207111/f3a039c67ba800a15791/

来源:java黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

4 0
收藏该文
已收藏

评论内容:(最多支持255个字符)