Arrays工具类、二维数组
Arrays工具类、二维数组
回顾
1.Idea的使用
2.数组的声明初始化方式
声明
int[] arr;
int arr[];//不推荐使用
初始化
2.1静态初始化
arr=new int[]{10,20,30};
int[] arr2=new int[]{3,4,5};
//简写 必须一条语句完成
int[] arr3={1,3,5};
2.2动态初始化
int[] arr4=new int[4];//创建数组,长度4,数组元素都是默认值 0
String[] arr5=new String[5]; //创建数组,长度5,数组元素都是默认值null
3.数组的使用(元素访问,元素修改,遍历)
3.1 访问元素 使用下标 ,下标范围 0 - 长度-1
3.2 获取长度 arr.length;
3.3 修改元素
arr[0]=10;
arr[1]=20;
arr[2]=30;
3.4 数组遍历
//for
for(int i=0;i<arr.length;i++){
System.out.println(arr[i]);
}
//增强for ,缺点不能访问下标
for(int num:arr){
System.out.println(num);
}
注意:1 数组不要越界 ArrayIndexOutofBoundsException
2 数组一定要初始化 NullPointerException
3.5数组内存空间的分配
栈:存储基本类型数据和引用类型的地址 ,特点:先进后出 空间比较小,访问速度较快
堆:存储引用类型的实际数据,特点:空间比较大,访问速度较慢
int[] nums=new int[]{20,30,40};
nums 数组 栈 地址
{20,30,40}存放在堆中
4.数组的应用(排序和查找)
排序:
4.1 冒泡排序
N个数字来排列
两两比较小靠前
外层循环n-1
内层循环n-1-i
for(int i=0;i<nums.length-1;i++){
for(int j=0;j<nums.length-1-i;j++){
if(nums[j]>nums[j+1]){
int temp=nums[j];
nums[j]=nums[j+1];
nums[j+1]=temp;
}
}
}
4.2 选择排序
N个数字来排列
选择一个来比较
外层循环n-1
内层循环小于n
for(int i=0;i<nums.length-1;i++){
for(int j=i+1;j<nums.length;j++){
if(nums[i]>nums[j]){
int temp=nums[i];
nums[i]=nums[j];
nums[j]=temp;
}
}
}
优化
for(int i=0;i<nums.length-1;i++){
int k=i;
for(int j=i+1;j<nums.length;j++){
if(nums[k]>nums[j]){
k=j; //最小的数的下标
}
}
if(k!=i){
int temp=nums[k];
nums[k]=nums[i];
nums[i]=temp;
}
}
查找:
4.3 顺序查找
4.4 二分法查找
1 先排序
2 每次从中间开始,进行比较
int low=0;
int upper=nums.length-1;
while(low<=upper){
int middle=(low+upper)>>1;
if(nums[middle]>key){
upper=middle-1;
}else if(nums[middle]<key){
low=middle+1;
}else{
return middle;
}
}
return -1;
今天内容
1.Arrays工具类
2.方法传参和返回值
3.可变参数
4.二维数组
1.1 二维数组的概念
1.2 二维数组的定义
1.3 数组的初始化
1.4 二维数组的访问
5.调试和文档注释
教学目标
1.掌握Arrays工具类的使用
2.掌握方法传参和返回值
3.掌握可变参数的使用
4.掌握二维数组的初始化和遍历
5.掌握调试和文档注释
第一节 Arrays工具类
使用帮助文档:
1.6
1.8
作用:主要用于对数组进行排序,查找,填充,比较等的操作
Arrays工具类存在于java.util包下,所以使用的第一步就是导包:import java.util.Arrays;
注意1:如果在同一个Java文件中同时使用Scanner和Arrays,则可以向如下方式导包:
import java.util.Scanner;
import java.util.Arrays;
或者简写为:* 所有的类
import java.util.*;
注意2:但凡是工具类,类中的方法全部是静态的,方便调用
调用语法:类名.方法名(实参列表)
代码实现:
//演示Arrays工具类的使用
package com.qf.day07;
import java.util.Arrays;
/*
* Arrays工具类的使用
* 1 二分查找
* 2 排序
* 3 复制
* 4 填充
* 5 把数组转成字符串
*
*
*/
public class Demo1 {
public static void main(String[] args) {
// binarySearch();
//sort();
//copy();
//fill();
toStr();
}
//binarySearch 二分查找
public static void binarySearch() {
int[] arr=new int[] {5,8,10,20,65,100};
int result=Arrays.binarySearch(arr,22);
if(result>=0) {
System.out.println("找到了");
}else {
System.out.println("没找到 ");
}
}
//排序
public static void sort() {
int[] arr=new int[] {12,8,100,2,9};
Arrays.sort(arr);
System.out.println("排序之后:");
for(int i=0;i<arr.length;i++) {
System.out.print(arr[i]+" ");
}
}
//复制
public static void copy() {
int[] arr=new int[] {12,8,100,2,9};
int[] arr2=Arrays.copyOf(arr, arr.length);
for(int i=0;i<arr2.length;i++) {
System.out.println(arr2[i]);
}
}
//填充
public static void fill() {
int[] arr=new int[] {12,8,100,2,9};
Arrays.fill(arr, 10);
for(int i=0;i<arr.length;i++) {
System.out.println(arr[i]);
}
}
//把数组转成字符串
public static void toStr() {
int[] arr=new int[] {12,8,100,2,9};
String s=Arrays.toString(arr);
System.out.println(s);
}
}
第二节 方法的传参和返回值
根据有没有参数:(1)无参方法 (2)有参方法
根据有没有返回值:(1)无返回值 (2)有返回值
2.1 基本类型作为方法的参数
案例1:交换两个数字
public class Demo2 {
public static void main(String[] args) {
int num1=10;
int num2=20;
swap(num1, num2);
System.out.println(num1);
System.out.println(num2);
}
public static void swap(int a,int b) {
System.out.println("交换之前: a:"+a+" b:"+b);
int temp=a;
a=b;
b=temp;
System.out.println("交换之后: a:"+a+" b:"+b);
}
}
2.2 引用类型作为方法的参数
案例2:实现数组排序
import java.util.Arrays;
/*
* 方法的参数传递和返回值
* 1 交换两个数字
* 2 实现数组排序
*
*/
public class Demo2 {
public static void main(String[] args) {
int[] nums=new int[] {15,8,3,9,20,50};
sort(nums);
//遍历nums
System.out.println("遍历nums");
for(int i=0;i<nums.length;i++) {
System.out.print(nums[i]+" ");
}
}
//2实现数组排序
public static void sort(int[] arr) {
//排序之前
System.out.println("排序之前");
System.out.println(Arrays.toString(arr));
//冒泡
for(int i=0;i<arr.length-1;i++) {
for(int j=0;j<arr.length-i-1;j++) {
if(arr[j]>arr[j+1]) {
int temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
//排序之后
System.out.println("排序之后");
System.out.println(Arrays.toString(arr));
}
}
总结: Java中的方法传参采用的是传值的方式。
1 基本类型传递的实际数据
2 引用类型传递的是地址
基本类型传递修改后对调用方没有任何影响。引用类型传递修改后对调用方有影响。String和包装类除外
2.3 基本类型作为方法返回值
案例3 编写一个方法,实现1-100和,并返回结果
public class Demo3 {
public static void main(String[] args) {
int result=sum();
System.out.println(result);
}
public static int sum() {
//计算1-100的和
int sum=0;
for(int i=0;i<=100;i++) {
sum+=i;
}
return sum;
}
}
2.4 引用类型作为方法返回值
案例4 : 编写一个方法,返回一个数组
package com.qf.day07;
import java.util.Arrays;
/*
* 方法返回值
* 1 基本类型作为方法返回值
* 2 引用类型作为方法返回值
*/
public class Demo3 {
public static void main(String[] args) {
int[] nums2=getNums();
for(int i=0;i<nums2.length;i++) {
System.out.println(nums2[i]);
}
}
//把数组中的每个数字加5,再返回一个数组
public static int[] getNums() {
int[] arr=new int[] {5,10,15};
for(int i=0;i<arr.length;i++) {
arr[i]=arr[i]+5;
}
return arr;
}
}
总结:方法的返回值如果是基本类型则返回实际数据,如果是引用类型则返回地址。
特殊:String类型和包装类传值方法和返回值遵循基本类型。
第三节 可变参数
不定长参数
在调用方法时,方法的形参的个数是不确定的
语法
类型... 变量名称
例如:int... num
好处:不用创建数组,直接写数组元素
代码实现:
package com.qf.day07;
/*
* 可变参数
* int...
* 好处:不用创建数组,直接写数组元素
* 注意事项:
* 1 一个方法只能有一个可变参数
* 2 可变参数只能方法参数列表最后
*/
public class Demo4 {
public static void main(String[] args) {
//调用
//int[] nums= {10,4,8,20};
//sort(nums);
sort(10,4,8,20,1,2); //实际运行是,把这些数据变成数组
}
public static void sort(int a,int... arr) {
for(int i=0;i<arr.length-1;i++) {
for(int j=0;j<arr.length-i-1;j++) {
if(arr[j]>arr[j+1]) {
int temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
}
}
注意:
a.不定长的参数在进行使用的时候被当做数组来进行处理
b.一个方法只能有一个可变参数
c. 可变参数只能方法参数列表最后
第四节 二维数组
4.1 二维数组的概念
本质上还是一个一维数组,只是其数组元素又是一个一维数组
举例说明:变量,一维数组,二维数组之间的关系
吸烟:
没钱 1根 一个变量
稍微有钱 一包 一维数组【20根】
有钱 一条 二维数组【10包】
4.2 二维数组的定义
方式一:元素类型[][] 数组名称;
方式二:元素类型 数组名称[][];
推荐使用方式一
4.3 数组的初始化
静态初始化:
语法:元素类型[][] 数组名称 = new 元素类型[][]{{一维数组1,一维数组2,一维数组3....};
简化:元素类型[][] 数组名称 =m{{一维数组1,一维数组2,一维数组3....};
举例:int[][] arr = new int[][]{{2,3},{5,2,1},{10,45,22,54}};
int[][] arr = {{2,3},{5,2,1},{10,45,22,54}};
动态初始化:
语法:元素类型[][] 数组名称 = new 元素类型[二维数组的长度][一维数组的长度]
举例:int[][] arr = new int[3][4];
说明:定义一个数组arr,二维数组中一维数组的个数为3个,每个一维数组中元素的个数为4个
4.4 二维数组的访问
通过下标访问二维的指定元素
class TwiceArrayDemo01
{
public static void main(String[] args)
{
int[][] arr = new int[3][4];
System.out.println(arr);//[[I@15db9742
System.out.println(arr.length);//3
System.out.println(arr[0]);//[I@6d06d69c
System.out.println(arr[0].length);//4
System.out.println(Arrays.toString(arr));//[[I@6d06d69c, [I@7852e922, [I@4e25154f]
System.out.println(Arrays.toString(arr[0]));//[0, 0, 0, 0]
/*
[[I@15db9742
3
[I@6d06d69c
4
[[I@6d06d69c, [I@7852e922, [I@4e25154f]
[0, 0, 0, 0]
*/
}
}
遍历二维数组
//常见的操作:遍历二维数组
class TwiceArrayDemo02
{
public static void main(String[] args)
{
//如果二维数组中一维数组的元素个数不确定
//int[][] arr = new int[3][];
int[][] arr = new int[][]{{2,3},{5,2,1},{10,45,22,54}};
//给arr[0]中的第0个元素修改值
arr[0][0] = 10;
//遍历arr[0]
for(int i = 0;i < arr[0].length;i++) {
System.out.println(arr[0][i]);
}
//二维数组的遍历:嵌套for循环
//简单for循环
for(int i = 0;i < arr.length;i++) {
int[] subArr = arr[i];
for(int j = 0;j < subArr.length;j++) {
System.out.println(subArr[j]);
}
}
//增强for循环
for(int[] subArr1:arr) {
for(int n:subArr1) {
System.out.println(n);
}
}
}
}
上机练习:一个班级有两门课程,5个学生,使用二维数组保存每门课的成绩,并计算每门课的总分和平均分
public static void main(String[] args) {
double[][] scores=new double[2][5];
Scanner input=new Scanner(System.in);
for(int i=0;i<scores.length;i++) {
for(int j=0;j<scores[i].length;j++) {
System.out.println("请输入第"+(i+1)+"门课,第"+(j+1)+"个学生的成绩");
scores[i][j]=input.nextDouble();
}
}
System.out.println("----------------------------");
for(int i=0;i<scores.length;i++) {
double sum=0;
for(int j=0;j<scores[i].length;j++) {
sum+=scores[i][j];
}
System.out.println("第"+(i+1)+"门课的总分是:"+sum);
System.out.println("第"+(i+1)+"门课的平均分是:"+(sum/5));
}
}
4.5 内存中的二维数组
public static void main(String[] args) {
int[][] nums={{10,20,30},{40,50,60}};
int[][] nums2={{1,2},{3,4},{5,6}};
int[][] nums3=new int[3][2];
int[][] nums4=new int[2][];
}
画图分析:
第五节:调试技巧
使用调试技巧,帮助开发人员理解程序执行过程,从而发现问题,解决问题。
使用eclipse调试程序需要两个步骤:
-
1添加断点:
-
2单步执行:
快捷键: F5单步进入 Step Into
F6单步跳过 Step Over
F7单步返回 Step Return
F8继续执行 Resume
查看变量窗口、断点窗口
使用Idea调试程序,同样需要两个步骤:
-
1添加断点:
-
2单步执行:
* 快捷键 * F8 step over 单步跳过 * F7 step into 单步进入 * Alt+Shift + F7 强制单步进入,进入其他的类库
第六节:文档注释
java中注释
- 单行注释://这里是单行注释
- 多行注释:/*这里是多行注释,
可以多行**/*
-
JavaDoc注释:用来注释类、属性和方法等
使用语法 /** .....*/
-
JavaDoc常用标签
标签 | 含义 | 标签 | 含义 |
---|---|---|---|
@author | 标识一个类的作者,例如 @author wgy | @version | 指定类的版本 |
@see | 指定参考的链接或内容 | @param | 说明一个方法的参数 |
@since | 标记一个特定的变化时,@since jdk1.2 | @return | 说明返回值类型 |
/**
* 学校类
* @author wgy
* @version 2.0 2018/03/20
*/
public class School {
/**
*学校名称
*/
String schoolName;
/**
* 招生方法
* @return total
*/
public void drawStudent() {
System.out.println(schoolName+"开始招生...");
}
//...
}
文档注释作用:
1.编写代码时可通过提示显示文档注释
2.JavaDoc 工具能够从源代码中抽取类、属性、方法等的注释,形成一个配套的API帮助文档 。
演示1:eclipse或idea生成帮助文档。注意编码 -encoding utf-8 -charset utf-8
演示2:javadoc -d doc -encoding utf-8 -charset utf-8 src\com\qf\day23_3\Person.java
总结
1 Arrays工具类 的使用
binarySearch() //二分查找
sort();// 排序
copyOf();// 复制数组
copyOfRange();
fill();// 填充
toString();//把数组转成字符串形式
2 方法的参数传递和返回值
1 方法的参数传递采用传值方式: 基本类型传递的实际数据 引用类型传递的地址
2 方法的返回值,返回数据,基本类型返回实际数据,引用类型返回地址。
3 二维数组,实际上是由一维数组组成,一维数组的每个元素还是一个数组。
4 二维数组的声明、初始化、访问(通过下标访问,遍历)
int[][] arr=new int[][]{{10,20},{30,40}}
5 调试技巧
1 添加断点
2 单步执行 F6单步跳过 F5单步进入 F8继续执行 ctrl+f12 终止调试
6 文档注释
帮助开发人员生成API文档
默写
根据下面要求完成题目:
1.分别使用静态初始化和动态初始化的方式定义一个数组
2.对静态初始化的数组分别使用冒泡和选择进行排序,其中,冒泡实现升序,选择实现降序
3.使用for循环和foreach遍历排好序的数组
作业
1.班上有3个学生,每个学生都参加了三门功课的考试,其中第二个学生是特长生,上级要求给他每门功课都+5.【要求:使用二维数组做,并且分别使用for循环和增强for循环遍历二维数组】
2.求一个3*3矩阵对角线元素之和
10 20 30
8 6 7
20 25 50
面试题
1.二维数数组在内存中的存储方式是怎样的?