java數(shù)組_2

命令行參數(shù)

在程序運(yùn)行過(guò)程中,可以向應(yīng)用程序傳遞一些參數(shù),這些參數(shù)稱(chēng)為命名行參數(shù)

public class Test01{

??? publicstatic void main(String[] args){

?????? System.out.println(args.length);


?????? for(inti= 0;i

?????????? System.out.println(args[i]);

?????? }

??? }

}

命令行參數(shù)以字符串的形式傳入args數(shù)組中??梢砸淮蝹鬟f0-多個(gè)參數(shù),以空格分割。

如果參數(shù)中本身包含空格,需要使用引號(hào)。

Arrays

jdk中為了便于開(kāi)發(fā),給開(kāi)發(fā)者提供了Arrays類(lèi),其中包含了很多數(shù)組的常用操作。例如快速輸出、排序、查找等。

常用方法

import java.util.Arrays;

public class Test02{

??? publicstatic void main(String[] args){


?????? int[]arr = {4,2,3,1};

?????? //【1】數(shù)組的字符串形式

?????? Stringstr = Arrays.toString(arr);

?????? System.out.println(str);


?????? //【2】sort對(duì)數(shù)組排序(只能升序)-> 內(nèi)部使用快速排序。

?????? Arrays.sort(arr);

?????? System.out.println(Arrays.toString(arr));


??? ??? //【3】fill 填充數(shù)組

?????? //Arrays.fill(arr,0);

?????? //System.out.println(Arrays.toString(arr));


?????? //【4】equals(arr1,arr2) 判斷兩個(gè)數(shù)組是否相等。

?????? //數(shù)組相等的條件:a.長(zhǎng)度相等 b.對(duì)應(yīng)位置元素相等。

?????? int[]arr2 = {1,2,3};

?????? System.out.println(Arrays.equals(arr,arr2));

??? }

}

二分法查找

private static int binarySearch0(long[] a,int fromIndex, int toIndex,long key){

???????int low = fromIndex;

???????int high = toIndex - 1;


???????while (low <= high) {

???????????int mid = (low + high) >>> 1;

? ??????????long midVal = a[mid];


???????????if (midVal < key)

??????????????? low = mid + 1;

???????????else if (midVal > key)

??????????????? high = mid - 1;

???????????else

??????????????? return mid; // key found

???????}

???????return -(low + 1);?// key notfound.

??? }

二分法查找必須是有序的數(shù)組,如果找到返回索引;

如果沒(méi)有找到,返回-插入點(diǎn)-1。插入點(diǎn)是key應(yīng)該放到數(shù)組的位置。

數(shù)組的復(fù)制

copyOf(arr,len) 把a(bǔ)rr復(fù)制len個(gè)長(zhǎng)度的元素并返回新數(shù)組。如果len>arr.length,新數(shù)組的長(zhǎng)度末尾用0填充。

copyOfRange(arr,from,to) 從arr中from(包含)位置開(kāi)始復(fù)制到to(不包含)這個(gè)范圍的元素到新數(shù)組中。含頭不含尾。

import java.util.Arrays;

public class Test04{

??? publicstatic void main(String[] args){


?????? int[]arr = {1,3,4,6,8};


?????? int[]newArr = Arrays.copyOf(arr,6);

?????? System.out.println(Arrays.toString(newArr));


?????? //copyOfRange(arr,from,to)

?????? int[]newArr2 = Arrays.copyOfRange(arr,1,3);

?????? System.out.println(Arrays.toString(newArr2));

??? }

}

其中System也提供了賦值數(shù)組的方法。

arraycopy(srcArr,srcPos,destArr,destPos,len)

srcArr:要復(fù)制的源數(shù)組

srcPos:從srcArr的srcPos位置開(kāi)始復(fù)制

destArr:復(fù)制到的目標(biāo)數(shù)組

destPos:目標(biāo)數(shù)組從destPos開(kāi)始存放

len:從源數(shù)組中復(fù)制len個(gè)長(zhǎng)度

int[] arr2 = new int[arr.length];

System.arraycopy(arr,1,arr2,0,3);

System.out.println(Arrays.toString(arr2));

二維數(shù)組

? ? ?二維數(shù)組基礎(chǔ)

二維數(shù)組是數(shù)組的數(shù)組,數(shù)組的元素也是數(shù)組。如圖:

二維數(shù)組表示行列二維結(jié)構(gòu)。

二維數(shù)組的聲明

根據(jù)二維數(shù)組的定義

import java.util.Arrays;

public class Test05{

??? publicstatic void main(String[] args){

? ? ? ?//二維數(shù)組

?????? //int[]

?????? //(int[]) []


?????? //【1】聲明

?????? int[][]arr;

?????? //【2】初始化一個(gè)能存3個(gè)一維數(shù)組的二維數(shù)組

?????? arr= new int[3][];


?????? //【3】賦值

?????? int[]arr1 = {1,3,4,5};

?????? int[]arr2 = {1,3,4};

?????? int[]arr3 = {2,1,6,4};


?????? arr[0]= arr1;

?????? arr[1]= arr2;

?????? arr[2]= arr3;


?????? System.out.println(arr);

?????? System.out.println(Arrays.toString(arr));

??? }

}

此時(shí)arr = new int[3][];只分配了二維數(shù)組的空間,一維數(shù)組沒(méi)有分配空間。


聲明一個(gè)規(guī)則的二維數(shù)組

import java.util.Arrays;

public class Test06{

??? public? static void main(String[] args){


?????? //聲明一個(gè)規(guī)則的二維數(shù)組,3行4列

?????? int[][]? arr;

?????? arr? = new int[3][4];


?????? arr[0][0]? = 10;

?????? arr[0][1]? = 20;

?????? arr[0][2]? = 30;

?????? arr[0][3]? = 40;


?????? arr[1][0]? = 100;

?????? arr[1][1]? = 200;

?????? arr[1][2]? = 300;

?????? arr[1][3]? = 400;


?????? arr[2][0]? = 1000;

?????? arr[2][1]? = 2000;

?????? arr[2][2]? = 3000;

?????? arr[2][3]? = 4000;


?????? System.out.println(Arrays.toString(arr));

??? }

}

此時(shí),二維數(shù)組已經(jīng)分配好空間,同時(shí)一維也分配好空間。


當(dāng)已知二維數(shù)組的值數(shù),可以考慮字面量聲明。

import java.util.Arrays;

public class Test07{

??? public? static void main(String[] args){


?????? //聲明字面量二維數(shù)組

?????? int[][]? arr = {

?????????? {10,20,30,40},

?????????? {100,200,300},

?????????? {1000,2000,3000,4000}

?????? };

?????? System.out.println(Arrays.toString(arr));

??? }

}

二維數(shù)組的遍歷

import java.util.Arrays;

public class Test08{

??? public? static void main(String[] args){


?????? //聲明字面量二維數(shù)組

?????? int[][]? arr = {

?????????? {10,20,30,40},

?????????? {100,200,300},

?????????? {1000,2000,3000,4000}

?????? };

?????? //? System.out.println(Arrays.toString(arr));


?????? /*

?????? for(int? i=0;i

?????????? int[]? t = arr[i];

?????????? for(int? j=0;j

????????????? System.out.print(t[j]+"\t");

?????????? }

?????????? System.out.println();

?????? }

?????? */



?????? for(int? i=0;i

?????????? for(int? j=0;j

????????????? System.out.print(arr[i][j]+"\t");

?????????? }

?????????? System.out.println();

?????? }

??? }

}

總結(jié):

二維數(shù)組是行列結(jié)構(gòu),使用雙層for循環(huán),外層for用于控制行,內(nèi)層for用于控制列

行列結(jié)構(gòu)=> 雙層for遍歷。


基本數(shù)據(jù)類(lèi)型和引用數(shù)據(jù)類(lèi)型賦值的區(qū)別

import java.util.Arrays;

public class Test09{

??? public? static void main(String[] args){


?????? //基本數(shù)據(jù)類(lèi)型的賦值

?????? int? a = 10;

?????? int? b;

?????? b? = a;

?????? //? a? b?

?????? b? = 20;

?????? //? a? b?


?????? //引用數(shù)據(jù)類(lèi)型的賦值

?????? int[]? arr = {1,3,5};

?????? int[]? arr2 = arr;

?????? arr2[0]? = 100;


?????? System.out.println("arr:"+arr);

?????? System.out.println("arr2:"+arr2);


?????? System.out.println("arr[0]:"+arr[0]);


??? }

}

總結(jié):

基本數(shù)據(jù)類(lèi)型賦值時(shí),復(fù)制的是值

引用數(shù)據(jù)類(lèi)型賦值時(shí),復(fù)制的是引用。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 【程序1】 題目:古典問(wèn)題:有一對(duì)兔子,從出生后第3個(gè)月起每個(gè)月都生一對(duì)兔子,小兔子長(zhǎng)到第三個(gè)月后每個(gè)月又生一對(duì)兔...
    開(kāi)心的鑼鼓閱讀 3,394評(píng)論 0 9
  • 第四天 數(shù)組【悟空教程】 第04天 Java基礎(chǔ) 第1章數(shù)組 1.1數(shù)組概念 軟件的基本功能是處理數(shù)據(jù),而在處理數(shù)...
    Java幫幫閱讀 1,682評(píng)論 0 9
  • DAY 05 1、 public classArrayDemo { public static void mai...
    周書(shū)達(dá)閱讀 833評(píng)論 0 0
  • Java經(jīng)典問(wèn)題算法大全 /*【程序1】 題目:古典問(wèn)題:有一對(duì)兔子,從出生后第3個(gè)月起每個(gè)月都生一對(duì)兔子,小兔子...
    趙宇_阿特奇閱讀 2,077評(píng)論 0 2
  • 我 想見(jiàn)你 趁這明的過(guò)分的月色暗淡之前 我 想見(jiàn)你 趁這鶯歌燕舞草長(zhǎng)鶯飛的季節(jié) 我 想愛(ài)你 在你與我對(duì)視的那...
    石頭會(huì)化閱讀 205評(píng)論 0 0

友情鏈接更多精彩內(nèi)容