一、二维数组以及多维数组

1、二维数组的定义:

​ 在一维数组中定义每一个元素也是一个数组元素,这样的数组称为”二维数组“

​ 多维数组就是在一维数组上再次定义二维数组或三位数组等。

​ 一维数组定义 int [] array={1,2,3}

//定义三个长度的二维数组,其数组的每一个元素是一个一维数组
int [][] arrays={{},{},{}};
或者
int [][] arrays=new int [3][2];//等号右边的左边[]中表示二维数组的长度,其中2可以省略,3不能省略
//注意:等号左边有几个[]就表示几维

//1、定义二维数组
int [][] array;
//定义时给二维数组赋值 3个长度的二维数组里面的一维数组的长度不一定相等
int [][] array2={{1,2,3},{4,5},{7,8}}
//定义时只指定大小,不给定初始值
int [][]array3=new int[3][];//等价{{},{},{}}
//array3[0][0]=1;//赋值时 空指针异常,因为里面的一维数组是空的
//定义一个3个长度的二维数组,里面的元素长度是2
int array4[][]=new int[3][2];
//给元素赋值
array4[0][0]=1;
//输出二维数组中的所有元素
for(int i=0;i<array4.length;i++){
//System.out.println(array4[i]);
for(int j=0;j<array4[i].length;j++){
System.out.println(array[i][j]);
}
}

二、二维数组的应用

1、定义5*5的矩阵,计算最大值最小值

public class Test{
public static void main(String[] args) {
//定义一个5*5的二维数组
int [][] array=new int[5][5];
//定义最大值,并初始化
int max=0;
//定义最小值,并初始化
int min=0;
//为二维数组中的每一个元素赋上一个0-100的整数值,并遍历输出二维数组
for (int i = 0; i <array.length ; i++) {
for (int j = 0; j <array[i].length ; j++) {
array[i][j]=(int)(Math.random()*100);
System.out.print(array[i][j]+"\t");
}
System.out.println();//换行
}
//将数组中的第一个元素赋值给max
max =array[0][0];
for (int i = 0; i <array.length ; i++) {
for (int j = 0; j <array[i].length ; j++) {
//如果数组中元素大于max,则将元素赋值给max
if(array[i][j]>=max){
max=array[i][j];
}
}
}
//输出二维数组中的最大值
System.out.println("最大值为:"+max);
//将数组中的第一个元素赋值给min
min =array[0][0];
for (int i = 0; i <array.length ; i++) {
for (int j = 0; j <array[i].length ; j++) {
//如果元素小于min,则将元素赋值给min
if(array[i][j]<=min){
min=array[i][j];
}
}
}
//输出二维数组中的最小值
System.out.println("最小值为:"+min);
}
}

2、五子棋游戏

public class Test{
//定义一个字符串型20*20的二维数组
static String [][] qipan=new String[20][20];
public static void main(String[] args) {
System.out.println("------------------------------五子棋游戏------------------------------");
//初始化棋盘
for (int i = 0; i <qipan.length; i++) {
for (int j = 0; j <qipan[i].length; j++) {
qipan[i][j]="+";
}
}
printQipan();
System.out.println("游戏开始:");
Scanner sc=new Scanner(System.in);
while(true) {
System.out.println("请玩家(黑棋)落子:");
System.out.print("请输入棋子的行数(1-20):");
int num1 = sc.nextInt();
System.out.print("请输入棋子的列数(1-20):");
int num2 = sc.nextInt();
if (num1 <= 0 || num1 > 20 || num2 <= 0 || num2 > 20 ) {
System.out.println("落子超出棋盘边界,请重新落子!");
continue;
} else {
if( qipan[num1 - 1][num2 - 1] != "+"){
System.out.println("该位置已有棋子,请重新落子!");
continue;
}else{
qipan[num1-1][num2-1]="";
}
}
//白棋落子
int row=0;
int col=0;
// System.out.println("白棋思考中...");
while(true){
row=(int)(Math.random()*20);
col=(int)(Math.random()*20);
if(qipan[row][col]=="+"){
break;
}
}
qipan[row][col]="●";
//打印棋盘
printQipan();
//判断输赢
if(judge()){
System.out.println(s+"赢了");
break;
}
}
}
//打印棋盘
public static void printQipan(){
for (int i = 0; i <qipan.length ; i++) {
for (int j = 0; j <qipan[i].length ; j++) {
System.out.print(qipan[i][j]+"\t");
}
System.out.println();
}
}
//判断输赢的方法
static String s="";
public static boolean judge(){
boolean flag=false;
for (int i = 0; i <qipan.length; i++) {
for (int j = 0; j <qipan[i].length ; j++) {
if(qipan[i][j]==""||qipan[i][j]=="●"){
//判断横向
if(j<16&&
qipan[i][j]==qipan[i][j+1]
&&qipan[i][j]==qipan[i][j+2]
&&qipan[i][j]==qipan[i][j+3]
&&qipan[i][j]==qipan[i][j+4]){
s=qipan[i][j];
flag=true;
break;
}
//判断右斜下
else if(i<16&&j<16&&qipan[i][j]==qipan[i+1][j+1]
&&qipan[i][j]==qipan[i+2][j+2]
&&qipan[i][j]==qipan[i+3][j+3]
&&qipan[i][j]==qipan[i+4][j+4]){
s=qipan[i][j];
flag=true;
break;
}
//判断纵向
else if(i<16&&qipan[i][j]==qipan[i+1][j]
&&qipan[i][j]==qipan[i+2][j]
&&qipan[i][j]==qipan[i+3][j]
&&qipan[i][j]==qipan[i+4][j]){
s=qipan[i][j];
flag=true;
break;
}
//判断左斜下
else if(i<16&&j>3&&qipan[i][j]==qipan[i-1][j-1]
&&qipan[i][j]==qipan[i-2][j-2]
&&qipan[i][j]==qipan[i-3][j-3]
&&qipan[i][j]==qipan[i-4][j-4]){
s=qipan[i][j];
flag=true;
break;
}
}
}
}
return flag;
}
}

拓展:利用二分法查找数组中的元素

public class Test {
public static void main(String[] args) {
// 1、指定一个20个长度的数组 随机数
int [] array=new int[20];
for (int i = 0; i <array.length; i++) {
array[i]=(int)(Math.random()*100);
}
//输出数组中的每一个元素
System.out.println("数组中的元素为:");
System.out.println(Arrays.toString(array));
// 2、排序 (升序)
Arrays.sort(array);
//输出排序后的数组
System.out.println("排序后的数组为:");
System.out.println(Arrays.toString(array));
// 3、输入一个目标数
Scanner sc=new Scanner(System.in);
System.out.print("请输入想要查找的数字:");
int num=sc.nextInt();
// 3、比较
//定义 最小值下标 最大值下标 中间值下标 查找的目标下标
/**
* 最小下标 0
* * 最大下标 length-1
* *
* * 循环条件: 最小值小标<=最大值下标
* 中间下标: middle = (最小值+最大值)/2
* * 如果中间值比目标大 说明 在左边 改变最大值下标 = 中间值下标-1
* * 如果中间值比目标小 说明 在右边 改变最小值小标 = 中间值下标+1
* * 如果相等 就break
* * 一直这样比较 结束的条件是什么
*/
//最小值小标
int minIndex=0;
//最大值下标
int maxIndex=array.length-1;
//中间值下标
int middle;
//目标值下标
int index=-1;
//计数器
int count=0;
while(minIndex<=maxIndex){
count++;
middle=(minIndex+maxIndex)/2;
if(num<array[middle]){
maxIndex=middle-1;
}else if(num>array[middle]){
minIndex=middle+1;
}else {
index=middle;
break;
}
}
if(index!=-1){
System.out.println("目标已找到");
System.out.print("共查询次数:"+count+"\n");
System.out.print("目标数下标为:"+index);
}else{
System.out.println("目标不存在");
}
}
}

Java二维数组以及多维数组的定义及应用的更多相关文章

  1. JAVA二维数组的复制

    JAVA二维数组的复制 笔者今天做一道ccf题目时,遇到要将二维数组拷贝复制时,没有用常规的那种一个一个数的复制,用的是System.arraycopy()来进行复制,下面介绍这个函数的一些注意点: ...

  2. java 二维数组的行列长度

    在 java 中,其实只有一维数组,而二维数组是在一维数组中嵌套实现的.比如 int[][] a = {{},{},{},{}} 要取行数和某一行的列数可以 : int rowLen = a.leng ...

  3. 06-01 Java 二维数组格式、二维数组内存图解、二维数组操作

    二维数组格式1 /* 二维数组:就是元素为一维数组的一个数组. 格式1: 数据类型[][] 数组名 = new 数据类型[m][n]; m:表示这个二维数组有多少个一维数组. n:表示每一个一维数组的 ...

  4. “全栈2019”Java第三十一章:二维数组和多维数组详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  5. Java 二维数组

    在 Java 中,二维数组与一维数组一样,但是不同于 C 中的二维数组: 1. 在 Java 中,二维数组可以看成是以数组为元素的数组,例如:  int a[][] = {{1,2},{3,4,5,6 ...

  6. Java 二维数组,排序、切换顺序,查表法二进制十进制,这班查找、排序(冒泡、选择)、遍历,获取最大小值(4)

    Java 二维数组,排序.切换顺序,查表法二进制十进制,折半查找.排序(冒泡.选择).遍历,获取最大小值(4)

  7. 062 01 Android 零基础入门 01 Java基础语法 07 Java二维数组 01 二维数组应用

    062 01 Android 零基础入门 01 Java基础语法 07 Java二维数组 01 二维数组应用 本文知识点:二维数组应用 二维数组的声明和创建 ? 出现空指针异常 数组的名字指向数组的第 ...

  8. Java二维数组转成稀疏sparsearray数组

    稀疏数组 基本介绍 当一个数组中大部分元素为0,或者为同一个值的数组时,可以使用稀疏数组来保存该数组. 稀疏数组的处理方法是: 记录数组一共有几行几列,有多少个不同的值 把具有不同值的元素的行列及值记 ...

  9. 【Java学习笔记之八】java二维数组及其多维数组的内存应用拓展延伸

    多维数组声明 数据类型[][] 数组名称; 数据类型[] 数组名称[]; 数据类型数组名称[][]; 以上三种语法在声明二维数组时的功能是等价的.同理,声明三维数组时需要三对中括号,中括号的位置可以在 ...

  10. Java二维数组的概念和使用方法

    二维数组 数组的数组---二维数组的每一个元素是一个一维数组 定义格式 数据类型[][] 数组名 = new 数据类型[二维数组的长度/包含的一维数组的个数][每个一维数组的长度]; int[][] ...

随机推荐

  1. Windows 10 G 神州网信政府版

    ​神州网信政府版2018版:Win10 CMGE_V0-H.1020.000.iso校验码:9484e568c6505f9c4ad5b9fcf7ec8d83588eebfb38089f53e33011 ...

  2. ArchLinux 作业系统安装教程

    如果你能看到此文,想必你一定玩过不少的发行商发行的 Linux 作业系统或者听说过很多发行商发行的 Linux 作业系统.如果你玩过不少的 Linux 作业系统,对于安装系统可谓是轻车熟路,就是闭着眼 ...

  3. 小知识:IN和EXISTS的用法及效率验证

    环境: Oracle 19.16 多租户架构 经常会在网上看到有人写exists和in的效率区别,其实在新版本的数据库中,是不存在这个问题的,优化器会自己判断选择最优的执行计划. 为了直观的说明,我在 ...

  4. [C++STL教程]1.vector容器是什么?实用教程来啦!超简单易懂,拿来就用

    C++与传统的C语言有一个很大的区别,就是新增了标准模板库 STL(Standard Template Library),它是 C++ 标准库的一部分,不需要单独安装,只需要 #include 对应的 ...

  5. odoo 开发入门教程系列-一些用户界面

    一些用户界面 数据文件 (XML) 参考: 该主题关联文档可以查看Data Files. 上一章,我们通过CSV文件添加了数据.当需要添加数据格式简单时,用CSV格式还是很方便的,当数据格式更复杂时( ...

  6. day13-SpringBoot整合MyBatis/Plus

    SpringBoot整合MyBatis/Plus 1.SpringBoot整合MyBatis 1.1整合案例 需求:整合SpringBoot和Mybatis,向数据库中查询数据. 项目结构: 1.1. ...

  7. RochyLinux 8.6安装Oracle19c Client

    一.环境准备 1.1 软件下载 下载地址:https://www.oracle.com/database/technologies/oracle19c-linux-downloads.html 其中c ...

  8. SpringBoot的EnableCaching简述

    Spring Boot中的EnableCaching简述 spring boot中自带有数据缓存机制,主要通过其org.springframework.cache包下的各种类来实现. EnableCa ...

  9. 刷爆 LeetCode 周赛 339,贪心 / 排序 / 拓扑排序 / 平衡二叉树

    本文已收录到 AndroidFamily,技术和职场问题,请关注公众号 [彭旭锐] 提问. 大家好,我是小彭. 上周末是 LeetCode 第 339 场周赛,你参加了吗?这场周赛覆盖的知识点比较少, ...

  10. lua快速入门~在js基础上,知道Lua 和 Js 的不同即可

    lua 和 javaScript 差不多的,就是一些语法的细节不同,学过js,再注意一下下面的细节,就能上手了~ 快速入门,可以直接看一下菜鸟教程的lua:https://www.runoob.com ...