1、數組的定義 數組是相同數據類型的有序集合,數組是一種特殊類型的變數,是在記憶體中開闢的一片連續的存儲空間 數組的元素:數組中的保存的具體的值 數組的長度:數組中能保存的最大得元素的個數。 數組的下標:數組是通過下標標識元素在數組中的位置的,下標從0開始,到數組長度-1 註意:數組中元素的類型必須與 ...
1、數組的定義
數組是相同數據類型的有序集合,數組是一種特殊類型的變數,是在記憶體中開闢的一片連續的存儲空間
數組的元素:數組中的保存的具體的值
數組的長度:數組中能保存的最大得元素的個數。
數組的下標:數組是通過下標標識元素在數組中的位置的,下標從0開始,到數組長度-1
註意:數組中元素的類型必須與數組聲明時的數據類型一致。
2、數組的聲明、初始化、賦值
數組聲明時,電腦未分配記憶體空間。例:int[] nums;或者int nums[];兩張聲明方式都可以
nums=new int[5];這個動作是為數組分配記憶體空間。
數組中元素如果未被賦值,其預設初始值根據數據類型的不同而不同。int數據類型預設初始值為0、double數據類型預設初始值為0.0、boolean數據類型預設初始值為false
註意:數組的長度一旦聲明後,無法更改
數組中元素的數據類型不能混合存儲
方式1:
int[] nums;
nums=new int[5];
nums[0]=1;
nums[1]=2;
.........
方式2:
int[] nums=new int[5];
news[0]=1;
news[1]=2;
........
方式3:int[] nums={10,20,30,40,50};
方式4:int[] nums=new int[]{10,20,30,40,50};
錯誤方式1:
int[] nums;
nums={10,20,30,40,50};
錯誤方式2:int[5] nums={10,20,30,40,50};
錯誤方式3:int[] nums=new int[5]{10,20,30,40,50};
3、數組的遍歷——高級for迴圈
方式一:
int[] nums={10,20,30,40,50};
//遍曆數組, 數組名.length獲取數組的長度
for(int i=0;i<nums.length;i++){
System.out.println(nums[i]);
}
方式二:
這裡介紹一種新的迴圈,高級for迴圈(for-each迴圈)
高級for迴圈是JDK1.5以後的新特性
語法:
for(元素數據類型 變數名:數組或集合){
迴圈體
}
例:int[] nums={10,20,30,40,50};
for(int n:nums){
System.out.println(n);
}
執行過程:相當於把數組下標中元素取出來,賦值給int n,即int n=nums[i];
註意:元素的數據類型和數組的數據類型必須一致
使用場景:高級for迴圈的功能遜於for迴圈,它無法直接操作下標,主要用於遍曆數組
4、
案例1
1 import java.util.Scanner; 2 public class TestArray { 3 /* 4 根據用戶輸入的人數,動態創建數組,並獲取用戶輸入的成績,統計最高分,最低分和平均分 5 */ 6 public static void main(String[] args) { 7 Scanner in=new Scanner(System.in); 8 System.out.println("請輸入人數"); 9 int num=in.nextInt(); 10 double[] scores=new double[num]; 11 for(int i=0;i<scores.length;i++){ 12 System.out.println("請輸入第"+(i+1)+"名學生的成績"); 13 scores[i]=in.nextDouble(); 14 } 15 int sum=0,avg=0; 16 double max=scores[0]; 17 double min=scores[0]; 18 for(int i=0;i<scores.length;i++){ 19 sum+=scores[i]; 20 if(scores[i]>max){ 21 max=scores[i]; 22 } 23 if(scores[i]<min){ 24 min=scores[i]; 25 } 26 } 27 avg=sum/scores.length; 28 System.out.println("最大值:"+max+"\t最小值:"+min+"\t平均分:"+avg); 29 } 30 31 }
案例2
1 import java.util.Scanner; 2 public class TestArray { 3 public static int search(int[] arr,int num){ 4 //在數組arr中查詢指定元素,如果元素存在返回其下標,否則返回-1 5 int index=-1; 6 for(int i=0;i<arr.length;i++){ 7 if(arr[i]==num){ 8 index=i; 9 break; 10 } 11 } 12 return index; 13 } 14 15 public static void main(String[] args){ 16 int[] arr={12,34,23,56,3,65}; 17 int index=search(arr,3); 18 System.out.println(index); 19 } 20 }