配套视频教程

问题Java考试结束后,老师给张浩分配了一项任务,让他计算全班(30人)的平均分int stu1 = 95;

int stu2 = 89;

int stu3 = 79;

int stu4 = 64;

int stu5 = 76;

int stu6 = 88;

……

avg = (stu1+stu2+stu3+stu4+stu5…+stu30)/30;

数组

数组是一个变量,存储相同数据类型的一组数据

声明一个变量就是在内存空间划出一块合适的空间

声明一个数组就是在内存空间划出一串连续的空间

数组基本要素标识符:数组的名称,用于区分不同的数组

数组元素:向数组中存放的数据

元素下标:对数组元素进行编号,从0开始,数组中的每个元素都可以通过下标来访问

元素类型:数组元素的数据类型

数组长度固定不变,避免数组越界

数组中的所有元素必须属于相同的数据类型

使用数组步骤:

声明数组: 告诉计算机数据类型是什么int[ ] score1; //Java考试成绩

int score2[ ]; //oracle考试成绩

String[ ] name; //学生姓名

分配空间: 告诉计算机分配几个连续的空间score = new int[30];

avgAge = new int[6];

name = new String[30];

声明数组并分配空间

数据类型[ ] 数组名 = new 数据类型[大小] ;

赋值:向分配的格子里放数据

score[0] = 89;

score[1] = 79;

score[2] = 76;

……![image.png](http://upload-images.jianshu.io/upload_images/468490-40a98f27e4e44f00.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

方法1: 边声明边赋值

int[ ] score = {89, 79, 76};

int[ ] score = new int[ ]{89, 79, 76};方法2:动态地从键盘录入信息并赋值

Scanner input = new Scanner(System.in);

for(int i = 0; i < 30; i ++){score[i] = input.nextInt();

}4. 对数据进行处理:计算5位学生的平均分

int [ ] score = {60, 80, 90, 70, 85};

double avg;

avg = (score[0] + score[1] + score[2] + score[3] + score[4])/5;访问数组成员:使用“标识符[下标]”

int [ ] score = {60, 80, 90, 70, 85};

int sum = 0;

double avg;

for(int i = 0; i < score.length; i++){sum = sum + score[i];

}

avg = sum / score.length;### 例子

>计算全班学员的平均分

public static void main(String[ ] args) {int[ ] scores = new int[5]; //成绩数组

int sum = 0; //成绩总和

Scanner input = new Scanner(System.in);

System.out.println("请输入5位学员的成绩:");

for(int i = 0; i < scores.length; i++){

scores[i] = input.nextInt();

sum = sum + scores[i]; //成绩累加

}

System.out.println("平均分是:" + (double)sum/scores.length);

}### 数组使用常见错误

public class ErrorDemo1 {public static void main(String[ ] args){

int[ ] score = new int[ ];

score[0] = 89;

score[1] = 63;

System.out.println(score[0]);

}

}

public class ErrorDemo2 {public static void main(String[ ] args) {

int[ ] scores = new int[2];

scores[0] = 90;

scores[1] = 85;

scores[2] = 65;

System.out.println(scores[2]);

}

}

public static void main(String[ ] args){int[ ] score = new int[5];

score = {60, 80, 90, 70, 85};

int[ ] score2;

score2 = {60, 80, 90, 70, 85};

}#### 一个练习

> 有一个数列:8,4,2,1,23,344,12

循环输出数列的值

求数列中所有数值的和

猜数游戏:从键盘中任意输入一个数据,判断数列中是否包含此数

// 有一个数列:8,4,2,1,23,344,12

// 循环输出数列的值

// 求数列中所有数值的和// 猜数游戏:从键盘中任意输入一个数据,判断数列中是否包含此数

int[] array = {8,4,2,1,23,344,12};

Scanner scanner = new Scanner(System.in);

System.out.println("请输入一个数");

int num = scanner.nextInt();

int i = 0;

//拿数组中的每一个元素和num比较,如果想等,输出包含,否则,输出不包含

for(i = 0; i < array.length; i++)

{

if(array[i]==num)

{

System.out.println("包含");

break;

}

}

//说明循环了一圈都没有发现用户输入的值

if(i==array.length)

{

System.out.println("不包含");

}### 数组排序

>循环录入5位学员成绩,进行升序排列后输出结果

使用java.util.Arrays类

java.util包提供了许多工具类

Arrays类提供操作数组的方法,例排序、查询

Arrays类的sort()方法: 对数组进行升序排列……

int[] scores = new int[5]; //成绩数组

Scanner input = new Scanner(System.in);

System.out.println("请输入5位学员的成绩:");

for(int i = 0; i < scores.length; i++){

scores[i] = input.nextInt();

}

Arrays.sort(scores);

System.out.print("学员成绩按升序排列:");

for(int i = 0; i < scores.length; i++){

System.out.print(scores[i] + " ");

}### 查找数组中的最大值

>从键盘输入本次Java考试五位学生的成绩,求考试成绩最高分

// 从键盘输入本次Java考试五位学生的成绩,求考试成绩最高分//将5个成绩保存到数组中,

//然后,遍历数组,找出数组中最大的数

Scanner scanner = new Scanner(System.in);

System.out.println("请输入成绩");

int[] scores = new int[5];

//将5个成绩保存到数组中,

for(int i = 0; i < scores.length; i++)

{

System.out.println("输入第" + (i + 1) + "次成绩");

scores[i] = scanner.nextInt();

}

//然后,遍历数组,找出数组中最大的数

int max = scores[0];让max等于数组中第一个元素

for(int i = 1; i < scores.length; i++)

{

if(max < scores[i])

{

max = scores[i];//谁比他大,他就变成谁

}

}

System.out.println("最大值是" + max);### 数组插入算法

>有一组学员的成绩{99,85,82,63, 60},将它们按升序排列。要增加一个学员的成绩,将它插入成绩序列,并保持升序。

![image.png](http://upload-images.jianshu.io/upload_images/468490-91ddf9a656c28cc8.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

分析:

将成绩序列保存在长度为6的数组中

通过比较找到插入位置

将该位置后的元素后移一个位置

将增加的学员成绩插入到该位置

// 有一组学员的成绩{99,85,82,63, 60},将它们按升序排列。

// 要增加一个学员的成绩,将它插入成绩序列,并保持升序int[] scores = {99,85,82,63, 60};

Arrays.sort(scores);

for(int i = 0; i < scores.length; i++)

{

System.out.print(scores[i]+" ");

}

// 要增加一个学员的成绩,将它插入成绩序列,并保持升序

Scanner scanner = new Scanner(System.in);

System.out.println("请输入下一个学生成绩");

int input = scanner.nextInt();

int pos = 0;//用户输入的数在新数组中正确的插入位置

//遍历原始数组,找到要插入的位置

for(int i = 0; i < scores.length; i++)

{

if(input <= scores[i])

{

pos = i;

break;

}

}

//再建一个新的数组,包含6个元素

int[] scores2 = new int[6];

//拷贝旧数组从0开始

// 到pos位置的数到对应新数组同样下标中

for(int i = 0; i < pos; i++)

{

scores2[i] = scores[i];

}

scores2[pos] = input;

//拷贝旧数组从pos+1开始

// 到旧数组长度位置的数到对应新数组同样下标中

for(int i = pos+1; i < scores2.length; i++)

{

scores2[i] = scores[i-1];

}

for(int i = 0; i

{

System.out.print(scores2[i]+" ");

}### 字符逆序输出

将 一组乱序的字符进行排序

进行升序和逆序输出

![image.png](http://upload-images.jianshu.io/upload_images/468490-3af982fb57629829.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

1.创建数组存储原字符序列。

2.利用Array类的sort( )方法对数组进行排序,并循环输出。

3. 从最后一个元素开始,将数组中的元素逆序输出。char[] charArray2 = {'a','c','u','b','e','p','f','z'};

//字符串可以看成是字符数组

String str = "abcefpuz";

System.out.println(charArray2.length);

System.out.println(charArray2);

Arrays.sort(charArray2);

System.out.println(charArray2);

for(int i = charArray2.length - 1; i >= 0; i--)

{

System.out.print(charArray2[i]);

}在上一个练习的基础上改进:

向上一个练习中得到的升序字符序列中插入一个新的字符,要求插入之后字符序列仍保持有序

![image.png](http://upload-images.jianshu.io/upload_images/468490-15d0dc92ea4bddd3.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

### 字符串数组

>定义一个字符串数组,查找某个字符串在数组中出现的次数

String[] array = {"zhangsan","lisi","wangwu","lisi"};String name = "wangwu";

int count = 0;//count计数,数字num在数组中出现的次数

for(int i = 0; i < array.length; i++)

{

if(array[i].equals(name))

{

count++;

}

}

System.out.println(count);### 作业

1.歌手打分:

在歌唱比赛中,共有10位评委进行打分,在计算歌手得分时,去掉一个最高分,去掉一个最低分,然后剩余的8位评委的分数进行平均,就是该选手的最终得分。输入每个评委的评分,求某选手的得分。

2.现在有如下一个数组:

int oldArr[]={1,3,4,5,0,0,6,6,0,5,4,7,6,7,0,5};

要求将以上数组中的0项去掉,将不为0的值存入一个新的数组,生成新的数组为

java数组的四个要素_Java零基础系列教程04Java数组相关推荐

  1. java基本数据类型与封装类 示例_Java零基础系列教程10Java抽象与封装

    配套视频教程 软件出现的目的 用计算机的语言描述现实世界 用计算机解决现实世界的问题 为什么使用面向对象 世界由对象组成 面向对象的思想 描述 面向对象的世界 符合人类思维习惯 从现实中抽象出类分三步 ...

  2. java基础教程 类_Java零基础系列教程06初识类和对象

    配套视频教程 万物皆对象 分类是人们认识世界的一个很自然的过程,在日常生活中会不自觉地进行分类 身边的对象 顾客 姓名-张浩 年龄-20 体重-60kg 操作: 购买商品 收银员 员工号-10001 ...

  3. java二重循环换行_Java零基础系列教程05Java二重循环

    配套视频教程 循环回顾某次程序大赛,S1班有4名学员参加,学员的成绩由用户输入,计算该班参赛学员的平均分 二重循环若有3个班级各4名学员参赛,如何计算每个班级参赛学员的平均分? 使用二重循环实现--一 ...

  4. java变量三要素_Java零基础快速入门|变量

    本文章主要内容:字面量 变量概述 使用变量 变量分类 变量作用域 难点疑惑 学习目标:理解变量本质是什么,在开发中有什么用? 变量三要素是什么? 怎么声明变量? 怎么给变量赋值? 变量是如何分类的? ...

  5. C语言 二维数组定义和使用 - C语言零基础入门教程

    目录 一.二维数组简介 二.定义二维数组并初始化 1.定义二维数组 2.初始化二维数组 三.访问二维数组 四.修改二维数组 五.猜你喜欢 零基础 C/C++ 学习路线推荐 : C/C++ 学习目录 & ...

  6. C语言 数组定义和使用 - C语言零基础入门教程

    目录 一.数组简介 二.定义数组并初始化 1.定义数组 2.初始化数组 三.访问数组 四.修改数组 五.猜你喜欢 零基础 C/C++ 学习路线推荐 : C/C++ 学习目录 >> C 语言 ...

  7. java中的四个指令_JAVA命令学习系列(四) ---- jstat

    jstat(JVM Statistics Monitoring Tool)是用于监控虚拟机各种运行状态信息的命令行工具.他可以显示本地或远程虚拟机进程中的类装载.内存.垃圾收集.JIT编译等运行数据, ...

  8. 今天用Java开发主机IP扫描神器,零基础Socket编程详细

    目录 一.开发背景 二.准备工作 三.远程主机 IP 探测 四.核心算法 1.IP地址转化为十进制数 2.十进制数转化为IP地址 五.主机 IP 扫描神器界面 六.各功能代码及IP扫描演示 1.主机扫 ...

  9. C语言 使用指针遍历数组 - C语言零基础入门教程

    目录 一.使用数组下标遍历数组 1.计算数组元素个数 2.通过下标遍历数组 二.使用数组首地址偏移遍历数组 三.使用指针遍历数组 四.猜你喜欢 零基础 C/C++ 学习路线推荐 : C/C++ 学习目 ...

最新文章

  1. Sublime Text 3常用快捷键
  2. JavaScript之函数声明
  3. mysql命令:查看表结构
  4. 这本零差评且有趣的Python算法书有点火~
  5. ubuntu下mongodb启动脚本
  6. 初学QT遇到的“_on_OK_clicked(bool)未定义的引用”的问题,以及使用windows远程桌面登录树莓派
  7. 魔兽争霸3 冰封王座 w3g文件如何打开
  8. 机器学习(一)协同过滤推荐算法
  9. TrueType字体结构
  10. html字体名称有哪些,css有哪些字体系列?
  11. 【unity】动画状态机中Transition的settings两段动画如何设置?
  12. 如何把C盘里的文件默认位置更改到D盘指定目录?
  13. 计算机专业江苏考研,22考研,计算机专业江苏地区有哪些性价比高又好考的学校,快收藏吧!...
  14. 计算机网络- Internet是如何工作的
  15. Inventory 物料库存 mtl_transactions_interface 开发[转]
  16. Unity小游戏——3D坦克大战
  17. LaTeX打出字母上标、下标等
  18. Flask最强攻略 - 跟DragonFire学Flask - 第十五篇 Flask-Script
  19. 网络工程师常备工具_网络安全工程师应该知道的10种工具
  20. EasyRecovery15电脑版数据恢复工具 国内免费的数据恢复软件

热门文章

  1. LeetCode 606. 根据二叉树创建字符串(递归)
  2. LeetCode 41. 缺失的第一个正数
  3. clob和blob是不是可以进行模糊查询_你知道什么是 MySQL 的模糊查询?
  4. 文献阅读:知识图谱数据管理研究综述
  5. pandas数据分析选则接近数值的最接优方案
  6. 匈牙利算法-指派问题、二分图问题等
  7. Pytorch数据读取(Dataset, DataLoader, DataLoaderIter)
  8. 【LeetCode】3月25日打卡-Day10
  9. CentOS7完成mysql的安装和远程访问
  10. 【Codeforces 1096D】Easy Problem