java循环结构、数组
数组
数组是是多个相同类型数据按一定顺序排列的集合,并使用一个名字命名,并通过编号的方式对这些数据进行统一管理。
- 数组本身是引用数据类型,既可以存储基本数据类型,也可以存储引用数据类型。它的元素相当于类的成员变量。
- 创建数组对象会在内存中开辟一整块连续的空间,而数组名中引用的是这块连续空间的首地址。
- 数组的长度一旦确定,就不能修改。
- 通过下标(或索引)的方式调用指定位置的元素。
- 数组的分类:
按照维度:一维数组、二维数组、三维数组、…按照元素的数据类型分:基本数据类型元素的数组、引用数据类型元素的数组(即对象数组)
从六方面理解数组:
- 一维(二维)数组的声明和初始化
- 如何调用数组指定位置的元素
- 如何获取数组的长度
- 如何遍历数组
- 数组元素的默认初始化值
- 数组的内存解析
一维数组的使用
格式:type var[] 或 type[] var
1 //静态初始化:数组的初始化与数组元素的赋值同时进行
2 int[] num = new int[]{1,2,3,4,5};
3 //动态初始化:数组的初始化与数组元素的赋值分开进行
4 String[] names = new String[5];
5 name[0] = "11";
**数组一旦初始化完成,数组的长度就确定了。
每个数组都有一个属性length指明它的长度,例如数组a: a.length指明数组a的长度(元素个数)
数组的默认初始化值
对于基本数据类型:默认初始化值各有不同
对于引用数据类型:默认初始化值为null(注意:于0不同)


/*从键盘读入学生成绩,找出最高分,
并输出学生成绩等级。
成绩>=最高分-10 等级为’A’
成绩>=最高分-20 等级为’B’
成绩>=最高分-30 等级为’C’
其余 等级为’D’
提示:先读入学生人数,根据人数创建int数组,
存放学生成绩。*/ import java.util.Scanner;//在最上面 public class ArrayTest1 {
public static void main(String[] args) {
//调用Scanner输入学生的成绩
Scanner scan = new Scanner(System.in);
System.out.println("请输入学生的人数:");
int number = scan.nextInt(); //创建数组,存储学生的成绩。动态初始化
int[] score = new int[number];
int maxscore = 0;
//将学生的成绩赋值给数组
System.out.println("请输入"+ number +"个学生成绩");
for(int i=0 ; i<score.length ; i++){
score[i] = scan.nextInt();
//直接在遍历赋值时进行最大值的计算
if(maxscore <= score[i]){
maxscore = score[i];
}
} //获取数组中的最大值
/*int maxscore = 0;
for(int i=0;i<score.length;i++){
if(maxscore < score[i]){
maxscore = score[i];
}
}*/ //遍历数组,计算学生的成绩,并且输出等级
char level;
for(int i=0;i<score.length;i++){
if(maxscore - score[i] <=10){
level = 'A';
}else if(maxscore - score[i] <=20){
level = 'B';
}else if(maxscore - score[i] <=30){
level = 'C';
}else{
level = 'D';
} System.out.println("student" + i +"score is"+score[i]+"grade is "+level);
}
} }
多维数组的使用(二维)


1 //都是正确的
2 int[][] arr = new int[][]{{1,2},{2,3,4},{4,5,6}};
3
4 int[] arr1[] = new int[][]{{1,2},{2,3,4},{4,5,6}};
5
6 int arr2[][] = new int[][]{{1,2},{2,3,4},{4,5,6}};
7
8 int[][] arr3 = {{1,2},{2,3,4},{4,5,6}};//类型推断
9
10 int[][] arr4;
11 arr4 = {{1,2},{2,3,4},{4,5,6}};//错误的,无法识别数组的类型
数组的长度:

遍历二维数组(双层for循环)
for(int i = 0 ; i<arr.length ; i++) {
for(j = 0 ; j<arr[i].length ; j++) {
System.out.print(arr[i][j]+"");
}
System.out.println();
}
二维数组的使用
规定:二维数组分为外层数组的元素,内层数组的元素
int[][] arr = new int[4][3];
//外层元素:arr[0] 、arr[1]等
//内层元素:arr[0][0]等 //数组的默认值
int[][] arr = new int[4][3];
System.out.println(arr[0]);//输出地址值,外层元素的初始化值,就是地址值
System.out.println(arr[0][1]);//0,内存元素的初始化值,与一维数组相同 int[][] arr = new int[4][];
System.out.println(arr[0]);
//无论是什么类型的二维数组,后面一个没有数值,都输出null
System.out.println(arr[0][1]);//报错
二维数组的内存解析

数据的存储结构:
线性表(一对一):顺序表(例如:数组)、链表、栈、队列
树形结构(一对多):二叉树
图形结构(多对多)
声明:int[] x,y[]; 在给x,y变量赋值以后,以下选项允许通过编译的是:
int[] x,y[];相当于 int[] x;与 int[] y[]; a ) x[0] = y; no //x是一维的,y是二维的,x[0]就是int型的一个数
b) y[0] = x; yes
c) y[0][0] = x; no
d) x[0][0] = y; no
e) y[0][0] = x[0]; yes
f) x = y; no
java循环结构、数组的更多相关文章
- JAVA循环结构
JAVA循环结构:顺序结构只能执行一次,如果要执行多次需要用到循环 JAVA中的循环结构有while:do...while:for: 1.while循环:先判断布尔表达式中的值,若为true,执行循环 ...
- Java循环结构 - for, while 及 do...while
Java循环结构 - for, while 及 do...while 顺序结构的程序语句只能被执行一次.如果您想要同样的操作执行多次,,就需要使用循环结构. Java中有三种主要的循环结构: whil ...
- Java 循环结构
Java 循环结构 - for, while 及 do...while 顺序结构的程序语句只能被执行一次.如果您想要同样的操作执行多次,,就需要使用循环结构. Java中有三种主要的循环结构: whi ...
- Java-Runoob:Java 循环结构
ylbtech-Java-Runoob:Java 循环结构 - for, while 及 do...while 1.返回顶部 1. Java 循环结构 - for, while 及 do...whil ...
- Java 循环结构 - for, while 及 do...while
Java 循环结构 - for, while 及 do...while 顺序结构的程序语句只能被执行一次.如果您想要同样的操作执行多次,,就需要使用循环结构. Java中有三种主要的循环结构: whi ...
- JavaSE基础(八)--Java 循环结构
Java 循环结构 - for, while 及 do...while 顺序结构的程序语句只能被执行一次.如果您想要同样的操作执行多次,,就需要使用循环结构. Java中有三种主要的循环结构: whi ...
- Java循环结构之while和do-while循环
循环结构知识点 本章技能目标 1理解循环的含义 2会使用while循环 3会使用do-while循环 4会使用调试解决简单的程序错误 一. 循环的含义 循环就是重复的做……(Java程序中的循环结 ...
- 四、 java循环结构
for循环结构: 格式:①初始化条件;②循环条件;③迭代条件;④循环体 for(①;②;③){ //④ } 执行过程:①-②-④-③-②-④-③-...-④-③-②,直至循环条件不满足,退出当前的循环 ...
- 7、Java 循环结构
本章讲解一下Java中常见的三种循环结构,顺序结构的程序语句只能 被执行一次.使用循环可以解决我们多个常量或者变量的同一类的操作或者更加复杂的操作. 循环 循环结构有三大类: 1.for循环:确定循环 ...
- JAVA循环结构示例
本文章主要是帮助大家学习循环结构.学习循环时,最重要的是理清思路,那些最经典算法实际中我们并不会单拿出来用,而是会用到当时做这个算法时的思想.如果把这个思路想明白了,那么实际中用到他的时候自然而然就想 ...
随机推荐
- 操作系统思考 第十一章 C语言中的信号量
第十一章 C语言中的信号量 作者:Allen B. Downey 原文:Chapter 11 Semaphores in C 译者:飞龙 协议:CC BY-NC-SA 4.0 信号量是学习同步的一个好 ...
- Linux 文件、目录与磁盘格式
文件属性 连接数 文件持有者 文件所属群组 文件容量 文件最后修改时间 文件名(就那个..) 第一栏其中文件属性有10,第一个属性代表这个文件是目录.文件或链接文件: [d]目录 [-]文 ...
- docker-01
Docker介绍 1 什么是容器? Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源 Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移 ...
- SpringCloud-技术专区-从源码层面让你认识Feign工作流程和运作机制
Feign工作流程源码解析 什么是feign:一款基于注解和动态代理的声明式restful http客户端. 原理 Feign发送请求实现原理 微服务启动类上标记@EnableFeignClients ...
- AQS源码分析看这一篇就够了
好了,我们来开始今天的内容,首先我们来看下AQS是什么,全称是 AbstractQueuedSynchronizer 翻译过来就是[抽象队列同步]对吧.通过名字我们也能看出这是个抽象类 而且里面定 ...
- Vulnhub -- DC4靶机渗透
用nmap扫描ip和端口,发现只开启了22ssh端口和80http端口 打开网页只有一个登录界面 目录爆破没有发现什么有用的,尝试对登录进行弱口令爆破 一开始使用burpsuite,使用一个小字典进行 ...
- Java实现WebSocket服务
一.使用Tomcat提供的WebSocket库 Java可以使用Tomcat提供的WebSocket库接口实现WebSocket服务,代码编写也非常的简单.现在的H5联网游戏基本上都是使用WebSo ...
- 剑指 Offer 68 - II. 二叉树的最近公共祖先
剑指 Offer 68 - II. 二叉树的最近公共祖先 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先. 百度百科中最近公共祖先的定义为:"对于有根树 T 的两个结点 p.q,最近 ...
- 浅看spa单页应用路由
路由观察浏览器的URL的变更.当URL 变更时,路由会解析它并生成一个新的路由实例. 一个基本的路由是这样的: class Router { private _defaultController: s ...
- 综合练习——寻找有潜力的bilibili百大UP主(1)
寻找有潜力的bilibili百大UP主(1) 防喷说明:以下仅为个人学习之余的娱乐项目,本人不主动赋予以下内容任何价值,不确保内容的准确性 欢迎各位友善的指出错误 目录 寻找有潜力的bilibili百 ...