第4章 数组(6课时)

常见异常

java.lang.ArrayIndexOutOfBoundsException: 5

at com.neuedu.test.Chap04.test01(Chap04.java:14)

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)

at java.lang.reflect.Method.invoke(Unknown Source)

at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)

at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)

at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)

at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)

at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)

at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)

at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)

at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)

at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)

at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)

at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)

at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)

at org.junit.runners.ParentRunner.run(ParentRunner.java:363)

at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)

at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)

at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459)

at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:678)

at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)

at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)

定义:

数组可以看成是多个相同类型数据的组合,实现对这些数据的统一管理

元素:数组里的每个值叫做一个元素

索引index:是数据在数组里存放的位置 (编号)  索引从0开始

{1,2,3,4,5}   3的索引为2

数组元素类型:可以是任何类型(四类八种基本类型+引用类型)

分类:

一维数组

 多维数组


一维数组定义

两种定义方式 

1)数组类型  数组名称[]

int a[];

2)数组类型[]  数组名称

int[] b;

给数组指定长度

int a[]=new int[4];

给数组赋值

     //第一种,用下标(索引)方式给数组赋值

      a[0]=56;

      a[1]=45;

      a[2]=18;

      a[3]=11;

      a[4]=9;

学生练习

定义一个长度为5的一维数组,给他赋值 ,并用for循环打印元素值

@Test

public void test1() {

//定义数组的两种方式

      int a[]=new int[5];

      int[] b=new int[5];

      //数组是引用类型 把地址存到栈里,把数据存到堆里

    给数组赋值

      第一种,用下标方式给数组赋值

      a[0]=56;

      a[1]=45;

      a[2]=18;

      a[3]=11;

      a[4]=9;

      //System.out.println(a[2]);

      //得到数组长度

      int len=a.length;

      //for循环打印数组的每个值

      for(int i=0;i<len;i++){

      System.out.println(a[i]);

      }

}

第二种创建同时赋值

数组类型  数组名[ ] = {元素1,元素2,…}

数组类型 数组名[ ] = new 数据类型[ ]{元素1,元素2,…}

int [] a=new int[]{1,2,3};

int [] a={3,4,5};

学生练习:

用这种方式改造刚才的程序

加强for循环(以后常用)

格式:

for(数组元素类型  循环到的变量命名 所循环的数组名){

 语句;

}

课堂练习

编写一个长度为5的整型数组,每个元素赋值为0-10的随机整数,遍历该数组,输出每个元素。

@Test

public void test3(){

int a[]=new int[5];

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

int r=new Random().nextInt(10);

a[i]=r;

}

for(int b:a){

System.out.println(b);

}

}

数组越界异常

ArrayIndexOutOfBoundsException

作业

1)线上学习多维数组的创建、初始化、内存模型

2)背冒泡排序

3)今天课堂代码写一下

数组的遍历

因为数组有下标,数组的遍历本质上是利用数组的下标,循环下标读取数据。

课堂练习:


学生练习:

1)从键盘输入班级学员成绩,计算全班学员的平均分

2)从键盘输入班级学员成绩,找出全班学员的最高分

数组复制


System.arraycopy(src, srcPos, dest, destPos, length);

//src:从哪里拷 源数组 拷贝谁

  //srcPos:从源数组中的第几个下标开始  源数组中的起始位置

  //dest:目标数组

  //destPos:目标数组中的起始位置

  //length:要复制的数组元素的个数

/**

    * 已知两个一维数组:{1,2,3,4,5}和{6,7,8},将这两个一维数组合并成一个一维数组{1,2,3,4,5,6,7,8}。

    */

@Test

    public void exam04(){

    int[] a={1,2,3,4,5};

    int b[]={6,7,8};

    int c[]=new int[a.length+b.length];

    //src源数组从哪里拷 源数组 拷贝谁

    //srcPos 起始位置的索引号

    //dest 目标数组

    //destPos 放到c的起始位置

    //length拷贝几个

    //把a复制到c里

    System.arraycopy(a, 0, c, 0, a.length);

    //把b复制到c里

    System.arraycopy(b, 0, c, a.length, b.length);

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

    System.out.println(c[i]);

    }

    }

数组排序

Arrays.sort(c)  全排

int c[]={4,1,8,9,6,2,1,0};

   Arrays.sort(c);

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

  System.out.println(c[i]);

  }

Arrays.sort(c, fromindex, toindex);   从哪个索引到哪个索引处进行排序,其他的不动。

 //从指定位置到终止位置进行排序

  Arrays.sort(c, 3, c.length);

  System.out.println("指定位置排序");

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

  System.out.println("---->"+c[i]);

}


课堂练习:

1)将一个字符数组的值(neusofteducation)拷贝到另一个字符数组中。(知识点:数组复制)

2 )给定一个有9个整数(1,6,2,3,9,4,5,7,8)的数组,先排序,然后输出排序后的数组的值。

冒泡排序:


//冒泡排序

@Test

public void sort(){

int[] a = { 1, 6, 2, 3, 9, 4, 5, 7, 8 };

int len=a.length;

//1、n个数排序,外层的循环n-1次  i=0~n-1

for(int i=0;i<len-1;i++){//0 ~n-1

//2、里层循环j=0~n-1-i次

for(int j=0;j<len-1-i;j++){

//循环体里比对  如果a[j]>a[j+1]  两个数就交换,大的会被交换到最下面】

if(a[j]>a[j+1]){

int temp=a[j];

a[j]=a[j+1];

a[j+1]=temp;

}

}

}

System.out.println("排序后:");

for(int i=0;i<len;i++){

System.out.println(a[i]);

}

}

@Test

public void sort2(){

int[] a = { 1, 6, 2, 3, 9, 4, 5, 7, 8 };

int len=a.length;

//1、n个数排序,外层的循环n-1次  i=1~n(不包括n)

for(int i=1;i<len;i++){//1 ~n

//2、里层循环j=0~n-i次

for(int j=0;j<len-i;j++){

//循环体里比对  如果a[j]>a[j+1]  两个数就交换,大的会被交换到最下面】

if(a[j]>a[j+1]){

int temp=a[j];

a[j]=a[j+1];

a[j+1]=temp;

}

}

}

System.out.println("排序后:");

for(int i=0;i<len;i++){

System.out.println(a[i]);

}

}

二维数组的创建和遍历

public static void main(String[] args) {

//创建并初始化数组

        //int[][] a=new int[][]{{1,2,3},{4,5,6}};

        int[][] a={{1,2,3},{4,5,6}};

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

        //a[0]={1,2,3} a[1]={4,5,6}

        for(int j=0;j<a[i].length;j++){

        System.out.println(a[i][j]);

        }

        }}

作业:

1)键盘输入班级学员成绩,计算全班学员每科的平均分     3科    5人

@Test

public void score() {

// 从键盘输入班级学员成绩,计算全班学员每科的平均分 (约定好是3科5人)

Scanner sc = new Scanner(System.in);

int[][] scores = new int[3][5];

while (true) {

// 逐科输入,一共输入3科

label: {

for (int i = 0; i < 3; i++) {// 几科

System.out.println("开始输入第" + i + "科学员成绩");

// 每科输入5个人的

int sum = 0;

for (int j = 0; j < 5; j++) {// 5人

System.out.println("请输入第" + j + "个学员成绩");

int score = sc.nextInt();// 第i科第j个学员成绩

if (score < 0 || score > 100) {

System.out.println("成绩不合法,重头再来");

break label;

}

scores[i][j] = score;

sum += score;

}

// 平均分=每科总成绩/总人数

double avg = sum / 5;

System.out.println("平均成绩" + avg);

}

}

// 循环打印用户输入的成绩

for (int i = 0; i < 3; i++) {

for (int j = 0; j < 5; j++) {

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

}

System.out.println();

}

}

}

2)第4章课后习题

补充:

选择排序:



//选择排序

@Test

public void selectSort(){

//原始数据{ 3, 6, 8, 1}

//1、在一个长度为 N 的无序数组中,第一次 假设min=第一个数 遍历后面 n-1 个数找到最小的和第一个数交换。

      //第一次假设 min=3  { 3, 6, 8, 1};  {1,6,8,3}

//2、第二次从下一个数开始遍历 n-2 个数,找到最小的数和第二个数交换。

    //第二次假设 min=6  {1,6,8,3};  ==》{1,3,8,6};

//3、重复以上操作直到第 n-1 次遍历最小的数和第 n-1 个数交换,排序完成。

  //第三次假设 min=8  {1,3,8,6};  ==》{1,3,6,8};

int[] a={ 3, 6, 8,1};

int len=a.length;//4

//n个数,外层循环n-1次  0~n-1

for(int i=0;i<len-1;i++){

  //每一次,先假设当前这个数是最小值

int min=a[i];//a[0],a[1],a[2]

System.out.println("当前假设的最小值为:"+min);

//里层循环从下一个(i+1)开始到最后一个

for(int j=i+1;j<len;j++){

      if(a[j]<min){

      //交换a[j]和min

      int temp=a[j];

      a[j]=min;

      min=temp;

      }

}

System.out.println("这一软计算后的最小值为:"+min);

a[i]=min;

}

System.out.println("---------------------------");

for(int i=0;i<len;i++){

System.out.println(a[i]);

}

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容

  • mean to add the formatted="false" attribute?.[ 46% 47325/...
    ProZoom阅读 2,694评论 0 3
  • 第四天 数组【悟空教程】 第04天 Java基础 第1章数组 1.1数组概念 软件的基本功能是处理数据,而在处理数...
    Java帮帮阅读 1,594评论 0 9
  • 贪心算法 贪心算法总是作出在当前看来最好的选择。也就是说贪心算法并不从整体最优考虑,它所作出的选择只是在某种意义上...
    fredal阅读 9,225评论 3 52
  • /*【程序21】 * 作者 南枫题目:求1+2!+3!+...+20!的和 1. 程序分析:此程序只是把累加变成了...
    HUC南枫阅读 433评论 0 0
  • 50道经典Java编程练习题,将数学思维运用到编程中来。抱歉哈找不到文章的原贴了,有冒犯的麻烦知会声哈~ 1.指数...
    OSET我要编程阅读 6,958评论 0 9