新手小白学JAVA 数组 数组工具类 二维数组(1)

  • 需求:输出一年中每个月份的天数

  • */

public class TestArrayExec {

public static void main(String[] args) {

m ();//本方法用于输出每个月的天数,快速修复快捷键Ctrl+1

}

//打印需求:例如 1月有31天

public static void m () {

//1.创建数组用来存12个月的天数

int[] a = {31,28,31,30,31,30,30,31,30,31,30,31};

//2.输出每个月的天数打印到控制台

//数组的遍历–通过循环的方式–操作的是数组的下标

//循环开始:a[0]–数组中的第一个元素

//循环结束:a[a.length-1]–数组中的最后一个元素

//如何变化:++

//for(int i = 0 ; i <=a.length-1 ; i++) {

for(int i = 0 ; i <a.length ; i++) {

//a[i]–根据下标i来获取数组a中对应位置上元素的值

System.out.println((i+1)+“月有:”+a[i]+“天”);

}

}

}

1.8 练习-2:遍历数组,存入1到10


//需求:遍历数组,存入1-10

public static void m2() {

//1.创建数组–动态创建

int[] a = new int[10];

//2.遍历数组,依次给每个位置赋值

//循环开始:a[0]–数组中的第一个元素

//循环结束:a[a.length-1]–数组中的最后一个元素

//如何变化:++

for(int i = 0 ; i <= a.length-1 ; i++) {

//a[i]–根据下标i来获取数组a中对应位置上元素的值

a[i] = i+1;

}//for循环结束

//3.在存入10个数据之后,打印a数组

System.out.println(a);//[I@15db9742

//除了char类型的数组,其他类型的数组想要查看具体内容需要借助工具类Arrays

//Arrays.toString(要打印的数组的名字)来查看数组中的具体内容

System.out.println(Arrays.toString(a));//[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

}

1.9 练习-3:创建随机数组


需求:创建数组,数组中的内容是100以内的随机数

public static void m3() {

//1.创建数组–动态

int[] a = new int[10];

//2.遍历数组,给数组中的每个元素赋值

for(int i = 0 ; i <a.length ; i++) {

//100是自定义的数据,表示生成的随机整数的范围是[0,100)

a[i] = new Random().nextInt(100);

//a[i] = new Random().nextInt(100)+1;//取值范围前后都+1–>[1,101)

}

//3.使用数组的工具类查看数组中的元素

System.out.println(Arrays.toString(a));

}

2 数组工具类Arrays

===================================================================================

2.1 Arrays.toString(数组)


把数组里的数据,用逗号连接成一个字符串[值1,值2]

2.2 Arrays.sort(数组)


对数组进行排序,对于基本类型的数组使用的是优化后的快速排序算法,效率高

对引用类型数组,使用的是优化后的合并排序算法

2.3 练习:练习Arrays.sort(数组)


创建类: TestArraysSort.java

package cn.tedu.array;

import java.util.Arrays;

/*本类用于测试数组的工具类Arrays/

public class TestArraysSort {

public static void main(String[] args) {

//1.创建无序数组

int[] a = {21,96,75,23,25};

//底层使用的排序算法是进行优化后的快速排序算法

Arrays.sort(a);//对无序数组进行直接排序

System.out.println(Arrays.toString(a));

}

}

2.4 Arrays.copyOf(数组,新的长度)


把数组赋值成一个指定长度的新数组

新数组的长度 大于 原数组, 相当于复制,并增加位置

新数组的长度 小于 原数组, 相当于截取一部分数据

2.5 练习:练习Arrays. copyOf(数组,新的长度)


创建类: TestArraysCopyOf.java

package cn.tedu.array;

import java.util.Arrays;

/*本类用于练习数组的缩容与扩容/

public class TestArraysCopyOf {

public static void main(String[] args) {

//1.创建数组

int[] from = {1,2,3,4,5};//数组一旦创建,长度不可改变

//2.1 数组的普通复制

/**copyOf()用于完成数组的复制,两个参数:

  • 参数1:要复制哪个数组

  • 参数2:新数组的长度*/

int[] to = Arrays.copyOf(from, 5);

System.out.println(Arrays.toString(to));

//2.2数组的扩容

/**扩容:给数组扩大容量,新数组的长度>原数组的长度

  • 扩容思路:先创建对应长度的新数组,每个位置上都是默认值0

  • 然后从原数组中将元素复制到新数组,没有被覆盖的元素还是默认值0*/

int[] to2 = Arrays.copyOf(from, 10);

System.out.println(Arrays.toString(to2));

//2.3数组的缩容

/**缩容:缩小数组的容量,新数组的长度<原数组的长度

  • 缩容思路:先创建对应长度的新数组,每个位置上都是默认值0

  • 然后从原数组中复制指定个数的元素到新数组中,类似于截取*/

int[] to3 = Arrays.copyOf(from, 3);

System.out.println(Arrays.toString(to3));

//2.4指定首尾截取原数组中的元素

/**copyOfRange()用于完成数组的截取,3个参数:

  • 参数1:要截取哪个数组【原数组】

  • 参数2:从原数组的哪个下标开始

  • 参数3:到原数组的哪个下标结束

  • 注意:截取的元素包含开始下标处的元素,不包含结束下标处的元素*/

int[] to4 = Arrays.copyOfRange(from, 2, 4);

System.out.println(Arrays.toString(to4));

}

}

3 拓展之二维数组

===============================================================================

3.1 概念


存放数组的数组,也就是说数组里存的还是数组的数据形式

二维数组图示

3.2 创建二维数组


int[][] a = {{3,5},{7,9},{1,2}};

–创建外部数组,长度是3

–给每个外部数组的位置创建内部数组,每个内部数组的长度是2

–给每个内部数组进行数据初始化

–二维数组生成唯一的地址值

–把地址值交给引用类型变量a来保存

3.3 遍历二维数组


for (int i = 0; i < a.length; i++) {//遍历外部数组

for (int j = 0; j < a[i].length; j++) {//遍历内部数组

System.out.println(a[i][j]);//依次打印二维数组中每个元素的值

}

}

3.4 打印二维数组中的数据


package cn.tedu.array;

import java.util.Arrays;

/*本类用于打印二维数组中的数据/

public class TestArrays2 {

结局:总结+分享

看完美团、字节、腾讯这三家的一二三面试问题,是不是感觉问的特别多,可能咱们真的又得开启面试造火箭、工作拧螺丝的模式去准备下一次的面试了。

开篇有提及我可是足足背下了Java互联网工程师面试1000题,多少还是有点用的呢,换汤不换药,不管面试官怎么问你,抓住本质即可!能读到此处的都是真爱

  • Java互联网工程师面试1000题

image.png

而且从上面三家来看,算法与数据结构是必备不可少的呀,因此我建议大家可以去刷刷这本左程云大佬著作的 《程序员代码面试指南 IT名企算法与数据结构题目最优解》,里面近200道真实出现过的经典代码面试题。

  • 程序员代码面试指南–IT名企算法与数据结构题目最优解

image.png

  • 其余像设计模式,建议可以看看下面这4份PDF(已经整理)

image.png

  • 更多的Java面试学习笔记如下,关于面试这一块,我额外细分出Java基础-中级-高级开发的面试+解析,以及调优笔记等等等。。。

image.png

以上所提及的全部Java面试学习的PDF及笔记,如若皆是你所需要的,那么都可发送给你!

sQHB-1714724323373)]

而且从上面三家来看,算法与数据结构是必备不可少的呀,因此我建议大家可以去刷刷这本左程云大佬著作的 《程序员代码面试指南 IT名企算法与数据结构题目最优解》,里面近200道真实出现过的经典代码面试题。

  • 程序员代码面试指南–IT名企算法与数据结构题目最优解

[外链图片转存中…(img-1yTbksTz-1714724323374)]

  • 其余像设计模式,建议可以看看下面这4份PDF(已经整理)

[外链图片转存中…(img-jXhx5bxV-1714724323374)]

  • 更多的Java面试学习笔记如下,关于面试这一块,我额外细分出Java基础-中级-高级开发的面试+解析,以及调优笔记等等等。。。

[外链图片转存中…(img-8PNZaKog-1714724323374)]

以上所提及的全部Java面试学习的PDF及笔记,如若皆是你所需要的,那么都可发送给你!

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值