大数据开发工程师就业学习之旅-JAVA篇

一维数组的使用

  1. 数组的声明和初始化
int[] arr = new int[10]
String[] arr1 = new String[]{"Tom","Jerry"}
  1. 调用数组的指定元素:使用角标、索引、index
index从0开始
  1. 数组的属性:length,表示数组的长度
  2. 数组的遍历
  3. 数组元素的默认初始化值
  4. 一维数组的内存解析
前提,再main()中声明变量,int[] arr = new int[]{1,2,3};
虚拟机栈:main()作为一个栈帧,压入空间中。在main()栈帧中,存储着arr变量。arr记录着数组实体的首地址值。
堆:数组实体存储在堆空间中

在这里插入图片描述

在这里插入图片描述

二维数组的使用

二维数组:一维数组的元素,又是一个唯一数组构成了二维数组。
  1. 数组的声明和初始化
  2. 调用数组的指定元素:使用角标、索引、index
  3. 数组的属性:length,表示数组的长度
  4. 数组的遍历
  5. 数组元素的默认初始化值
  6. 二维数组的内存解析
    在这里插入图片描述
    在这里插入图片描述

数组的常用算法

  1. 数值型数组的特征值计算:最大值、最小值、总和、平均值等
  2. 数组元素的赋值。比如:杨辉三角,彩票随机生成数(6位;1-30;不能重复);回型数
  3. 数组的复制、赋值
  4. 数组的反转
  5. 数组的扩容、缩容
  6. 数组的查找
    线性查找
    二分法查找(前提:数组有序)
  7. 数组的排序
    冒泡排序:最简单
    图片来源https://forestcat.blog.csdn.net/
    快速排序:最常用
    图片来源https://forestcat.blog.csdn.net/

Arrays工具类的使用

常用的内部方法

toString()/ sort()/ binarySearch()

数组中的常见异常

ArrayindexOutOfBoundsException
NullPointerException

补充:

  1. 数组没有length()方法,String有length()方法
  2. 数组的索引,表示数组元素距离首地址的偏移量。因为第一个元素的地址与首地址相同,所以偏移量是0,所以从0开始。
  3. 快排时间复杂度O(nlogn)
  4. 最大子序列和,要求时间复杂度O(n)
class MaximumSubarrayDP {
  public int maxSubArray(int[] nums) {
     int currMaxSum = nums[0];
     int maxSum = nums[0];
     for (int i = 1; i < nums.length; i++) {
       currMaxSum = Math.max(currMaxSum + nums[i], nums[i]);
       maxSum = Math.max(maxSum, currMaxSum);
     }
     return maxSum;
  }
}
作者:Trusting Antonelliyjp
链接:https://leetcode.cn/circle/article/jV9WBW/
来源:力扣(LeetCode

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值