数组的定义:数组是一个变量,存储相同数据类型的一组数据!
声明一个变量就是在内存空间划出一块合适的空间
声明一个数组就是在内存空间划出一串连续的空间
数组的基本要素
标识符:数组的名称,用于区分不同的数组
数组元素:向数组中存放的数据
元素下标:对数组元素进行编号,从0开始,数组中的每一个元素都可以通过下标来访问
元素类型:数组元素的数据类型
使用数组四步法:
1、声明数组 int [ ] a;
2、分配空间 a = new int [ 5 ] ;
3、赋值 a [ 0 ] = 8;
4、处理数据 a [ 0 ] = a [ 0 ]*10;
数组赋值:
1、边声明边赋值
int [ ] score ={1,2,3};
int [ ] score = new int [ ] {1,2,3};
2、动态地从键盘录入信息并赋值
Scanner input = new Scanner(System.in);
for(int i = 0; i< 30; i++){
score[i]= input.nextInt();
}
对数据进行处理:计算5位学生的平均分
1.
int [ ] score = {90,80,70,60,50};
double avg;
avg = (score [0]+score [1]+score [2]+score [3]+score [4])/5;
2.
int [ ] score = {90,80,70,60,50};
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 [ ] score = new int [5]; //成绩数组
Scanner input = new Scanner(System.in);
System.out.println("请输入五位学生的成绩:");
for(int i=0;i<scores.length;i++){
scores [i] = input.nextlnt();
sum = sum + scores [i]; //成绩累加
}
System.out.println("平均分是:"+(double)sum/scores.length);
}
例2:循环输入5位学生成绩,进行升序、降序排列后输出结果
import java.util.Scanner;
public class ScoreSort{
public static void main(String[] args){
int [] scores=new int [5];
Scanner input = new Scanner(System.in);
for(int =0;i<scores.length;i++){
System.out.print("\n请输入第"+(i+1)+"个成绩");
scores[i]=input.nextInt();
}
System.out.println("排序前数组的顺序");
for(int i=0;i<scores.length;i++){
System.out.print(scores[i]+"\t");
}
Arrays.sort(scores);//升序排列
System.out.println("\n排序后数组的顺序");
for(int i=0;i<scores.length;i++){
System.out.print(scores[i]+"\t");
}
//降序排列
System.out.println("\n排序后数组的顺序");
for(int i=0;i<scores.length;i++){
System.out.print(scores[scores.length-1-i]+"\t");
}
}
}
例3:从键盘输入5位学生的成绩,求考试成绩的最高分
public class Max{
public static void main(String[] args){
int [] scores=new int [5];
Scanner input = new Scanner(System.in);
for(int =0;i<scores.length;i++){
System.out.print("\n请输入第"+(i+1)+"个成绩");
scores[i]=input.nextInt();
}
int max=score[0];
for (int i=1;i< score.length; i++){
if(scores[i]>max){
max=scores[i];
}
}
System.out.println("最高分为"+max);
}
}
例4:有一组学生的成绩{99,85,82,63,60},将他们升序排列,要增加一个学生的成绩,将它插入成绩序列,并保持升序。
import java.util.Scanner;
public class Insert{
public static void main(String[] args){
int[ ] list = new int[6];//长度为6的数组
list[0] = 99;
list[1] = 85;
list[2] = 82;
list[3] = 63;
list[4] = 60;
//定义插入的索引号默认插入到最后一位置
int index=6;
//输入一个插入的数
System.out.print("请输入要插入的数:");
Scanner input=new Scanner(System.in);
int num=input.nextInt();
for (int i=0; i<list.length;i++){
if(num>list[i]){
index=i;
break;
}
}
System.out.println("要插入的位置下标:"+index) ;
//元素后移
for(int i=list.length-1;i>index;i--){
list[i]=list[i-1];
}
list[index]=num;
for (int i = 0; i<list.length; i++){
System,out.print(list[i]+"\t");
}
}
}