day01~day03 概念相对比较多,多记忆就可以了。

从day04开始,要记的只有一个格式,和代码的执行流程。

更多的是去做一些相对比较综合的练习。

从day04开始,代码量就渐渐的增多了,要多思考多练习。

在练习的时候要连两点:

  1. 一上课的代码。
  2. 二作业。

在晚自习的时候,先拿着讲义从头到尾复习一下,把上课没来得及写完的代码在晚自习的时候写完

然后再写作业。

如果来不及,那么在自习或者休息的时候可以继续干。

如果目前课堂上和作业里面我能全部完成,还有一点时间我该怎么办?

我个人建议,往后预习,目前而言不需要额外去找很多的练习去做。

尽可能的多学点东西,再去写一个相对比较综合的练习。

从第四天开始,代码量逐渐的加了,所以在上课的时候,建议大家还是用电脑去学习。

因为手机的屏幕太小,上课看不清字的。

第一章 数组

1.1什么是数组

  1. 数组就是存储数据长度固定的容器,存储多个数据的数据类型要一致。

1.2数组定义格式

第一种(常用)

  1. 数据类型[] 数组名
  2. 示例:
  1. int[] arr;
  2. double[] arr;
  3. char[] arr;

第二种

  1. 数据类型 数组名[]
  2. 示例:
  1. int arr[];
  2. double arr[];
  3. char arr[];

1.3数组静态初始化

1.3.1什么是静态初始化

  1. 在创建数组时,直接将元素确定

1.3.2静态初始化格式

  • 完整版格式
    1. 数据类型[] 数组名 = new 数据类型[]{元素1,元素2,...};
    2. 举例:
    3. int[] arr = new int[]{1,2,3,4};
  • 简化版格式
    1. 数据类型[] 数组名 = {元素1,元素2,...};
    2. 举例:
    3. int[] arr = {1,2,3,4};

1.3.3静态初始化格式详解

  • 等号左边:
    • int:数组的数据类型
    • []:代表这是一个数组
    • arr:代表数组的名称
  • 等号右边:
    • new:为数组开辟内存空间
    • int:数组的数据类型
    • []:代表这是一个数组
    • {}:表示数组里面存储的所有元素

1.4数组元素访问

1.4.1什么是索引

  1. 每一个存储到数组的元素,都会自动的拥有一个编号,从0开始。
  2. 这个自动编号称为数组索引(index),可以通过数组的索引访问到数组中的元素。

1.4.2访问数组元素格式

  1. 数组名[索引];

1.4.3索引的作用:

  • 利用索引可以获取数组中的元素
  • 利用索引可以把数据存储到数组中

代码示例:

  1. public class ArrayDemo {
  2. public static void main(String[] args) {
  3. int[] arr = new int[3];
  4. //输出数组名
  5. System.out.println(arr); //[I@880ec60
  6. //输出数组中的元素
  7. System.out.println(arr[0]);
  8. System.out.println(arr[1]);
  9. System.out.println(arr[2]);
  10. }
  11. }

练习1:数组的遍历

遍历:把数组里面所有的元素都一一获取出来,并按照指定格式进行打印

输出格式:[1, 2, 3, 4, 5]

代码示例:

  1. //1.定义数组并存储元素
  2. int[] arr = {1, 2, 3, 4, 5};
  3. //2.遍历
  4. //在循环开始之前,打印左括号
  5. System.out.print("[");
  6. for (int i = 0; i < arr.length; i++) {
  7. //i 依次表示数组里面的每一个索引
  8. //arr[i] 依次表示数组里面的每一个元素
  9. if(i == arr.length -1){
  10. System.out.print(arr[i]);
  11. }else{
  12. System.out.print(arr[i] + ", ");
  13. }
  14. }
  15. //在循环结束之后,打印有括号
  16. System.out.print("]");

练习2:累加求和

需求:

  1. 定义一个数组,存储1,2,3,4,5
  2. 遍历数组得到每一个元素,求数组里面所有的数据和

代码示例:

  1. //1.定义数组并存储元素
  2. int[] arr = {1,2,3,4,5};
  3. //2.遍历数组并求和
  4. //累加思想:就是定义一个变量sum,把所有的元素都累加到sum当中
  5. int sum = 0;
  6. for (int i = 0; i < arr.length; i++) {
  7. //i 依次表示数组里面的每一个索引
  8. //arr[i] 依次表示数组里面的每一个元素
  9. //问:此时我是把i累加到sum中,还是把arr[i]累加到sum中
  10. //累加arr[i]
  11. sum = sum + arr[i];// +=
  12. }
  13. //3.输出
  14. System.out.println(sum);

练习3:统计个数

需求:

  1. 定义一个数组,存储1,2,3,4,5,6,7,8,9,10<br />遍历数组得到每一个元素,统计数组里面一共有多少个能被3整除的数字

代码示例:

  1. //1.定义数组并添加数据
  2. int[] arr = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
  3. //2.看到统计,就要想要计数器思想
  4. int count = 0;
  5. for (int i = 0; i < arr.length; i++) {
  6. //i 索引 arr[i] 元素
  7. if(arr[i] % 3 == 0){
  8. count++;
  9. }
  10. }
  11. //3.循环结束之后,表示所有的元素都已经判断完毕
  12. System.out.println(count);

练习4:变化数据

需求:

  1. 定义一个数组,存储1,2,3,4,5,6,7,8,9,10<br />遍历数组得到每一个元素,将其中的奇数扩大两倍,偶数变成二分之一
  1. //1.定义数组并存储元素
  2. int[] arr = {1,2,3,4,5,6,7,8,9,10};
  3. //2.遍历数组得到每一个元素
  4. //然后对每一个元素进行判断,如果是奇数,就*2。如果是偶数,就/2
  5. for (int i = 0; i < arr.length; i++) {
  6. //i 索引 arr[i] 元素
  7. if(arr[i] % 2 == 0){
  8. //写偶数的逻辑
  9. //先把数组里面的元素拿出来除以2,得到一个结果再赋值给原来的位置
  10. arr[i] = arr[i] / 2;
  11. }else{
  12. //写奇数的逻辑
  13. //先把数组里面的元素拿出来乘以2,得到一个结果再赋值给原来的位置
  14. arr[i] = arr[i] * 2;
  15. }
  16. }
  17. //3.遍历验证一下结果
  18. for (int i = 0; i < arr.length; i++) {
  19. System.out.print(arr[i] + " ");
  20. }

1.5 数组动态初始化

1.5.1什么是动态初始化

  1. 数组动态初始化就是只给定数组的长度,由系统给出默认初始化值。

1.5.2动态初始化格式

  1. 数据类型[] 数组名 = new 数据类型[数组长度];
  1. int[] arr = new int[3];

1.5.3动态初始化格式详解

等号左边:

  • int:数组的数据类型
  • []:代表这是一个数组
  • arr:代表数组的名称

等号右边:

  • new:为数组开辟内存空间
  • int:数组的数据类型
  • []:代表这是一个数组
  • 5:代表数组的长度

1.6 数组的练习

1.6.1数组最值

最大值获取:从数组的所有元素中找出最大值。

实现思路:

  • 定义变量,保存数组0索引上的元素
  • 遍历数组,获取出数组中的每个元素
  • 将遍历到的元素和保存数组0索引上值的变量进行比较
  • 如果数组元素的值大于了变量的值,变量记录住新的值
  • 数组循环遍历结束,变量保存的就是数组中的最大值

代码实现:

  1. //扩展1:max的值能不能写0?最好不要写0。
  2. // 一般都会赋值数组中的某个元素
  3. //扩展2:循环从0开始,或者循环从1开始,对结果有没有影响?
  4. // 没有
  5. // 如果循环从0开始,那么多了一次,自己跟自己比的过程。
  6. // 对结果没有任何影响,只不过多循环了一次而已。
  7. //1.定义数组存储元素
  8. int[] arr = {33,5,22,44,55};
  9. //2.定义一个变量max
  10. int max = arr[0];
  11. //3.遍历数组
  12. for (int i = 1; i < arr.length; i++) {
  13. // i 索引 arr[i] 元素
  14. if(arr[i] > max){
  15. max = arr[i];
  16. }
  17. }
  18. //4.当循环结束之后,max记录的就是最大值
  19. System.out.println(max);

1.6.2 遍历数组求平均额数

需求:生成10个1~100之间的随机数存入数组

1)求出所有数据的和

2)求所有数据的平均数

代码示例:

  1. import java.util.Random;
  2. public class ArrDemo13 {
  3. public static void main(String[] args) {
  4. //1.定义数组
  5. int[] arr = new int[10];
  6. //2.生成10个随机数存入数组
  7. Random r = new Random();
  8. for (int i = 0; i < arr.length; i++) {
  9. //生成随机数
  10. int number = r.nextInt(100) + 1;
  11. //把生成的随机数存入数组
  12. arr[i] = number;
  13. }
  14. //3.求和
  15. int sum = 0;
  16. for (int i = 0; i < arr.length; i++) {
  17. //累加
  18. sum = sum + arr[i];
  19. }
  20. //4.平均数
  21. int avg = sum / arr.length;
  22. //5.打印
  23. System.out.println(avg);
  24. }
  25. }

1.6.3交换数组中的数据

本题的前置练习1:

  1. 交换两个变量的值
  2. int a = 10;
  3. int b = 20;
  4. //把a原本的值做了临时存储
  5. int c = a;
  6. //把b的值交给了a。
  7. a = b;
  8. //把c的值交给b
  9. b = c;
  10. System.out.println(a);
  11. System.out.println(b);

本题的前置练习2:

  1. 0索引的元素跟最后一个元素进行交换
  2. int[] arr = {1,2,3,4,5};
  3. //第一个和最后一个交换
  4. // 5 2 3 4 1
  5. int temp = arr[0];
  6. arr[0] = arr[4];
  7. arr[4] = temp;
  8. for (int i = 0; i < arr.length; i++) {
  9. System.out.println(arr[i]);
  10. }

需求:定义一个数组,存入1,2,3,4,5。交换首尾索引对应的元素。

交换前:1,2,3,4,5

交换后:5,4,3,2,1

代码示例:

  1. //1.定义数组
  2. int[] arr = {1, 2, 3, 4, 5};
  3. //2.循环交换数据
  4. for (int i = 0, j = arr.length - 1; i < j; i++, j--) {
  5. //交换i和j指向的元素即可
  6. int temp = arr[i];
  7. arr[i] = arr[j];
  8. arr[j] = temp;
  9. }
  10. //3.遍历数组
  11. for (int i = 0; i < arr.length; i++) {
  12. System.out.println(arr[i]);
  13. }