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

Java基础语法three

一、一维数组
一维数组初始化

数据类型[] 数组名=new 数据类型[数组长度]//动态初始化

数据类型[] 数组名=new 数据类型[]{值}//静态初始化

数据类型[] 数组名={值}

数组长度一旦确定,就不可更改。

数组是序排序;

数组属于引用数据类型的变量,数组的元素可以是任意数据类型;

一维数组引用:数组名[索引/下标]

获取数组长度:数组名.length
如何遍历数组:
for (int i = 0; i < 数组名.length; i++) {System.out.println(数组名[i]);}

不同类型的一维数组默认初始化值:

整型:0

浮点型:0.0

char:0或'\u0000',而非'0'

boolean:false

引用类型:null

二、二维数组
二维数组初始化
数据类型[][]数组名=new 数据类型[一维数组的个数][一维数组的长度]//动态初始化
数据类型[][]数组名=new 数据类型[一维数组的个数][]//动态初始化
数据类型[][]数组名=new 数据类型[][]{{},{},{}……,{}}//静态初始化
获取数组长度:

数组名.length

数组名[索引].length

如何遍历数组:
public static void main(String[] args) {// TODO Auto-generated method stubint[][] arr = new int[][] { { 1, 2, 3 }, { 4, 5, 6 }, { 7, 8, 9 } };for (int i = 0; i < arr.length; i++) {for (int j = 0; j < arr[i].length; j++) {System.out.println(arr[i][j] + "\t");}System.out.println();}}
二维数组默认初始化值:

方式一:

public static void main(String[] args) {// TODO Auto-generated method stub//二维数组使用,二维数组分为外层,内层元素int[][] arr = new int[4][3];//arr[0]外层//arr[0][0]内层//默认初始化值System.out.println(arr[0]);//[I@4e50df2eSystem.out.println(arr[0][0]);//0System.out.println(arr);//[[I@1d81eb93}

外层元素初始化值为:地址值

内层元素初始化值为:与一维数组初始化情况相同

方式二:

public static void main(String[] args) {// TODO Auto-generated method stubint[][] arr = new int[4][];System.out.println(arr[0]);//null}

外层元素初始化值为:null

内层元素初始化值为:不能调用,会报错

三、数据结构

1、数据与数据之间的逻辑关系:集合,一对一,一对多,多对多;

2、数据的存储结构:

线性表:顺序表(数组)、链表、栈、队列;

树形结构:二叉树

图形结构

算法:排序算法,搜索算法

四、数组算法

10行的杨辉三角

public static void main(String[] args) {// TODO Auto-generated method stubint[][] arr = new int[10][];for (int i = 0; i < arr.length; i++) {arr[i] = new int[i + 1];arr[i][0] = arr[i][i] = 1;for (int j = 1; j < arr[i].length - 1; j++) {arr[i][j] = arr[i - 1][j - 1] + arr[i - 1][j];}}for (int i = 0; i < arr.length; i++) {for (int j = 0; j < arr[i].length; j++) {System.out.print(arr[i][j] + "\t");}System.out.println();}}

数组的复制、反转、遍历

int[] array1=new int[]{1,2,3,4};
//数组的复制,区别于数组变量的赋值:array1=array2
int[] array2=new int[array1.length];
for(int i=0;i<array1.length;i++){
array2[i]=array1[i];
}
//数组反转
for(int i=0;i<array1.length/2;i++){
int temp =array1[i];
array1[i]=array1[array1.length-i-1];
array1[array1.length-i-1]=temp;
}
//遍历
for(int i=0;i<array1.length;i++){
System.out.println(array1[i]+"\t");
}

查找(线性查找、二分法查找)

//线性查找int num=4;boolean flag=true;for(int i=0;i<array1.length;i++) {if(num==array1[i]) {System.out.println("找到指定元素,位置为,"+i);flag=false;break;}}if(flag) {System.out.println("很遗憾,没有找到");}//二分法查找:前提:所要查找的数组必须有序int[] arr=new int[]{12,43,2,-1,8,7,66,45};int n=-1;int head=0;//初始首索引int end=arr.length-1;//初始尾索引boolean flag1=true;while(head<=end) {int middle=(head+end)/2;if(n==arr[middle]) {System.out.println("找到指定元素,位置为,"+middle);flag1=false;break;}else if(arr[middle]>n) {end=middle-1;}else {head=middle+1;}}if(flag1) {System.out.println("很遗憾,没有找到");}

排序算法

衡量排序算法优劣:

时间复杂度、空间复杂度、稳定性

排序:选择排序、交换排序(冒泡排序,快速排序)、插入排序(直接插入、折半插入)、归并排序、桶式排序、基数排序

算法5大特性:输入、输出、有穷性、确定性、可行性

冒泡排序:

int[] arr= new int[]{2,4,3,5,1};
for(int i=0;i<arr.length-1;i++) {for(int j=0;j<arr.length-1-i;j++) {if(arr[j]>arr[j+1]) {int temp=arr[j];arr[j]=arr[j+1];arr[j+1]=temp;}}
}
for(int i=0;i<arr.length;i++) {System.out.println(arr[i]);
}

从平均时间来看:快速排序最佳

Arrays工具类使用

java.util.Arrays:操作数组的工具类,里面定义了很多操作数组的方法。

Arrays.equals(int[] a,int[] b):判断两个数组是否相等

Arrays.toString(int[] a):输出数组信息

Arrays.fill(int[] a,int val):将指定值填充到数组中

Arrays.sort(int[] a):对数组进行排序

常见异常:

数组角标越界异常:ArrayIndexOutOfBoundsException

空指针异常:NullPointerException

http://www.lryc.cn/news/626753.html

相关文章:

  • 【LeetCode题解】LeetCode 209. 长度最小的子数组
  • 机器学习-数据预处理全指南:从缺失值到特征编码
  • 如何选择汽车ECU的加密方法
  • ROS2核心模块
  • Nik Collection 6.2全新版Nik降噪锐化调色PS/LR插件
  • CreateRef和useRef
  • Java内功修炼(2)——线程安全三剑客:synchronized、volatile与wait/notify
  • Web前端调试与性能优化,Charles抓包工具的高效应用
  • YOLOv11 到 C++ 落地全流程:ONNX 导出、NMS 判别与推理实战
  • Vue透传 Attributes(详细解析)2
  • 极其简单二叉树遍历JAVA版本
  • CMake1:概述
  • 查看磁盘占用情况和目录大小
  • 企业架构及战略价值
  • 如何让FastAPI任务系统在失败时自动告警并自我修复?
  • 从零实现自定义顺序表:万字详解 + 完整源码 + 图文分析
  • 从“怀疑作弊”到“实锤取证”:在线面试智能监考重塑招聘公信力
  • 河南萌新联赛2025第六场 - 郑州大学
  • 数据库优化提速(一)之进销存库存管理—仙盟创梦IDE
  • 开源模型应用落地-安全合规篇-深度合成隐式标识的技术实现(五)
  • 无人机感知系统详解
  • Tomcat 性能优化终极指南
  • C++ std::sort的应用总结
  • Vue2封装Axios
  • Google Chrome v139.0.7258.139 便携增强版
  • 嵌入式音频开发(3)- AudioService核心功能
  • 嵌入式开发学习———Linux环境下网络编程学习(四)
  • 04-认证授权服务开发指南
  • 读《精益数据分析》:规模化(Scale)—— 复制成功,进军新市场
  • Kafka如何保证消费确认与顺序消费?