欢迎来到天天文库
浏览记录
ID:50051046
大小:147.50 KB
页数:18页
时间:2020-03-08
《Java程序设计教程 教学课件 作者 杨晓燕 Java5.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、第五章数组Java程序设计教程1本章主要内容一维数组多维数组2数组的概念数组是具有一定顺序关系的若干相同类型变量的集合体,组成数组的变量称为该数组的元素。数组属于构造类型。数组3数组作为一种特殊的数据类型具有以下特点:一个数组中所有的元素是同一类型;数组中的元素是有顺序的;数组中的一个元素通过数组名和数组下标来确定。4在使用数组时,会涉及到以下几个术语:数组名。数组名应该符合Java语言标识符的命名规则。数组的类型。因为数组是用来存储相同类型的数据,因此数组的类型就是其所存储的元素的数据类型。数组的长度。数组的长度指的是数组中可以容纳的元素的个数,而不是数组所占用的字节数。5一维数组的
2、声明一维数组声明的格式为:类型数组名[];或类型[]数组名;其中类型指出了数组中各元素的数据类型,包括基本类型和构造类型。数组名为一个标识符。“[]”指明了该变量是一个数组类型变量。例如:inta[];或int[]a;6一维数组的初始化1.初始化方式一直接给数组的每个元素赋上一个初始值,系统会自动根据所给的元素个数为数组分配一定的内存空间,一般在数组元素比较少时使用,一般形式为:类型数组名[]={值1,值2,……,值n};以下声明并初始化一个长度为3的整型数组:inta[]={1,2,3};72.初始化方式二初始化方式二需要使用new操作符为一个数组分配内存空间,然后为每个元素分别赋值
3、,格式如下:类型数组名[];数组名=new类型[数组长度];或简化为类型数组名[]=new类型[数组长度];8例5.1以数据35、22、51、10、60为例,利用冒泡排序法按降序排列。分析:一般来说,需要经过n-1轮循环才能完成全部的排序。原始数据:3522511060第一轮:3551226010第二轮:5135602210第三轮:5160352210第四轮:60513522109实现排序的程序如下:publicclassBubbleSort{publicstaticvoidmain(String[]args){inti,j;intintArray[]={35,22,51,10,60}
4、;intlen=intArray.length;for(i=1;iintArray[j+1])10{intt=intArray[j];intArray[j]=intArray[j+1];intArray[j+1]=t;}System.out.println("排序后的结果为:");for(i=0;i5、名[][];或类型[][]数组名;12直接为每一维分配空间,如inta[][]=newint[2][3];该语句创建了一个二维数组a,其较高一维含两个元素,每个元素为由3个整数构成的整型数组。13(2)从最高维开始,分别为每一维分配空间,如intb[][]=newint[2][];//最高维含2个元素,每个元素为一个整型数组b[0]=newint[3];//最高维第一个元素是一个长度为3的整型数组b[1]=newint[5];//最高维第二个元素是一个长度为5的整型数组14例5-3执行结果:ia3的长度=5ia4的长度=7ia5的长度=3ia5[0]的长度=2ia5[1]的长度=4ia6、5[2]的长度=315例5.4:二维数组的使用。程序结果:16for(i=0;i<3;i++)for(j=0;j7、115+20*j,40+20*i);g.drawString("arr3:",230,20);for(i=0;i<3;i++)for(j=0;j<3;j++)g.drawString(""+arr3[i][j],230+20*j,40+20*i);}}1718
5、名[][];或类型[][]数组名;12直接为每一维分配空间,如inta[][]=newint[2][3];该语句创建了一个二维数组a,其较高一维含两个元素,每个元素为由3个整数构成的整型数组。13(2)从最高维开始,分别为每一维分配空间,如intb[][]=newint[2][];//最高维含2个元素,每个元素为一个整型数组b[0]=newint[3];//最高维第一个元素是一个长度为3的整型数组b[1]=newint[5];//最高维第二个元素是一个长度为5的整型数组14例5-3执行结果:ia3的长度=5ia4的长度=7ia5的长度=3ia5[0]的长度=2ia5[1]的长度=4ia
6、5[2]的长度=315例5.4:二维数组的使用。程序结果:16for(i=0;i<3;i++)for(j=0;j7、115+20*j,40+20*i);g.drawString("arr3:",230,20);for(i=0;i<3;i++)for(j=0;j<3;j++)g.drawString(""+arr3[i][j],230+20*j,40+20*i);}}1718
7、115+20*j,40+20*i);g.drawString("arr3:",230,20);for(i=0;i<3;i++)for(j=0;j<3;j++)g.drawString(""+arr3[i][j],230+20*j,40+20*i);}}1718
此文档下载收益归作者所有