当前位置: 首页 > news >正文

数组相关学习

一、定义:

1.定义数组格式:

(1)动态初始化:只定义数组存储数据类型和长度,不定义数组具体数据。

                                数据类型[ ] 数组名 = new 数据类型[长度]

                                数据类型 数组名[ ] = new 数据类型[长度]

(2)静态初始化:直接给出数据。

                                数据类型[ ] 数组名 = {元素1,元素2,元素3,......}

二、操作:

1.获取数组长度:

(1)格式:数组名.length(注意:length不是方法,后面不加小括号

2.索引:

(1)定义:元素在数组中的位置(编号、下标)。

3.存储元素:

(1)格式:数组名[索引值] = 值

(2)手动添加数据:可使用Scanna套用循环添加;

          自动随机添加数据:可使用Random套用循环添加;

          注意:循环中可使条件小于数组长度array.length

3.获取元素:

(1)格式:数组名[索引]

4.遍历数组:

(1)for循环遍历,快捷键:数组名.fori

(2)数组操作常见问题:

a.数组索引越界异常_ArrayIndexOutOfBoundsException

b.空指针异常_NullPinterException

        当一个对象为null时,再调用这个对象中的其他成员。

三、数组相关练习:

1.随机产生10个【0,100】之间的整数,统计既是3的倍数又是5的倍数,但不是7的倍数的个数:

        Random rdm = new Random();int[] arr = new int[10];for (int i = 0; i < arr.length; i++) {arr[i] = rdm.nextInt(101);}int count = 0;for (int i = 0; i < arr.length; i++) {if (arr[i]%3==0&&arr[i]%5==0&&arr[i]%7!=0){count++;}System.out.print(arr[i]+",");}System.out.println(count);

2.定义一个数组{1,2,3,4},以【1,2,3,4】的形式输出:

        int[] arr = {1,2,3,4};System.out.print("[");for (int i = 0; i < arr.length; i++) {if (i == arr.length-1) {System.out.print(arr[i] + "]");}else {System.out.print(arr[i]+",");}}

3.键盘录入一个数据,给出这个数据在数组中的索引位置:

        Scanner sc = new Scanner(System.in);int[] arr = {1,5,9,8,6,4,2,3,0};int i = sc.nextInt();int flag = 0;for (int j = 0; j < arr.length; j++) {if (i == arr[j]){System.out.println(j);flag++;}}if (flag == 0){System.out.println(-1);}

4.数组复制:

        int[] arr1 = {1,2,3,5,8,9};int[] arr2 = new int[6];int j = 0;for (int i = 0; i < arr1.length; i++) {if (i==j) {arr2[j] = arr1[i];j++;}}System.out.print("[");for (int k = 0; k < arr2.length; k++) {if (k == arr2.length-1){System.out.print(arr2[k]+"]");}else {System.out.print(arr2[k]+",");}}

5.数组扩容,将数组{1,2,3,4,5}长度扩容到10:

        int[] OldArr = {1,2,3,4,5};int[] NewArr = new int[10];for (int i = 0; i < OldArr.length; i++) {NewArr[i] = OldArr[i];}OldArr = NewArr;System.out.println(OldArr.length);for (int i = 0; i < OldArr.length; i++) {System.out.print(OldArr[i]+",");}

6.数组合并,将arr1{1,2,3}和arr2{4,5,6}合并成一个新数组:

        int[] arr1 = {1,2,3};int[] arr2 = {4,5,6};int[] NewArr = new int[arr1.length + arr2.length];for (int i = 0; i < arr1.length; i++) {NewArr[i] = arr1[i];}int len = arr1.length;for (int i = 0; i < arr2.length; i++) {/*已经将arr1数值插入到NewArr中,所以arr2要从arr1最后一个索引位置的后一位开始*/NewArr[len+i] = arr2[i];}for (int i = 0; i < NewArr.length; i++) {System.out.print(NewArr[i]+",");}
http://www.lryc.cn/news/600193.html

相关文章:

  • Pandas 处理缺失数据
  • 日语学习-日语知识点小记-构建基础-JLPT-N3阶段(10):ような复习
  • Windows-WSL-Docker端口开放
  • 在 Ansys CFX Pre 中配置 RGP 表的分步指南
  • Haprxy七层代理
  • iOS —— 天气预报仿写总结
  • Zookeeper 3.6.3【详细技术讲解】整
  • GaussDB 数据库架构师修炼(九) 逻辑备份实操
  • 继承接口实现websocke,实现任意路径链接
  • 从0开始学习R语言--Day57--SCAD模型
  • Spring Boot2 静态资源、Rest映射、请求映射源码分析
  • Sklearn 机器学习 数值指标 均方误差MSE
  • 黑马点评常见面试题
  • 通过Deepseek找工作
  • RocketMQ学习系列之——客户端消息确认机制
  • 【AI论文】Franca:用于可扩展视觉表示学习的嵌套套娃聚类
  • 第七章 愿景11 琦琦复盘测试
  • Yolo底层原理学习(V1~V3)(第一篇)
  • Java研学-RabbitMQ(二)
  • C语言————原码 补码 反码 (超绝详细解释)
  • JAVA_FourTEEN_常见算法
  • 笔试——Day18
  • LlamaIndex 和 Elasticsearch Rerankers:无与伦比的简洁
  • Mysql实现高可用(主从、集群)
  • 【运维】ubuntu 安装图形化界面
  • iOS苹果和Android安卓测试APP应用程序的区别差异
  • 地铁逃生
  • 浅谈生成式AI语言模型的现状与展望
  • gig-gitignore工具实战开发(三):gig add基础实现
  • 服务端处于 TIME_WAIT 状态的 TCP 连接,收到相同四元组的 SYN 后会发生什么?详解