欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java超細致講解數(shù)組的使用

 更新時間:2022年05月07日 15:27:35   作者:菜菜不恰菜  
數(shù)組對于每一門編程語言來說都是重要的數(shù)據(jù)結(jié)構(gòu)之一,當(dāng)然不同語言對數(shù)組的實現(xiàn)及處理也不盡相同。Java?語言中提供的數(shù)組是用來存儲固定大小的同類型元素

數(shù)組的定義

數(shù)組本質(zhì)上就是讓我們能 " 批量 " 創(chuàng)建相同類型的變量。

數(shù)組的三種語法格式

1、 數(shù)據(jù)類型 [] 數(shù)組名稱 = new 數(shù)據(jù)類型 [] { 初始化數(shù)據(jù) };

例如:

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

注意:[]里面不能寫數(shù)字?。?!

2、 數(shù)據(jù)類型 [] 數(shù)組名稱 = new 數(shù)據(jù)類型 [元素個數(shù)];

例如:

public class TsetModer {
    public static void main(String[] args) {
        int[] arr={1,2,3,4,5,6};
        for(int x:arr){
            System.out.print(x+" ");
        }
    }
}
int[] arr=new int[3];

3、 數(shù)據(jù)類型 [] 數(shù)組名稱 = { 初始化數(shù)據(jù) };

例如:

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

注意:[]里面不能寫數(shù)字?。。?/p>

遍歷數(shù)組的三種方式

1、用for循環(huán)遍歷數(shù)組

例如:

public class TsetModer {
    public static void main(String[] args) {
        int[] arr={1,2,3,4,5,6};
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i]+" ");
        }
    }
}

運行結(jié)果:

2、用for-each來遍歷數(shù)組

舉個例子:

public class TsetModer {
    public static void main(String[] args) {
        int[] arr={1,2,3,4,5,6};
        for(int x:arr){
            System.out.print(x+" ");
        }
    }
}

運行結(jié)果:

3、借助Java中操作數(shù)組的工具類Arrays.toString(將參數(shù)的數(shù)組以字符的形式輸出)

例如:

public class TsetModer {
    public static void main(String[] args) {
        int[] arr={1,2,3,4,5,6};
        System.out.println(Arrays.toString(arr));
    }
}

運行結(jié)果:

我們可以看到它打印出來的形式跟上面兩種方法都不一樣, 我們可以用to.String來模擬實現(xiàn)Arrays.toString。

public class TsetModer {
public static String toString(int[] arr) {
        String str="[";
        for (int i = 0; i < arr.length; i++) {
            str=str+arr[i];
            if(i!=arr.length-1){
                str=str+",";
            }
        }
        str=str+"]";
        return str;
    }
    public static void main(String[] args) {
        int[] arr={1,2,3,4,5,6};
        String ret=toString(arr);
        System.out.println(ret);
    }
}

數(shù)組的使用

數(shù)組傳參

先來看個例子:

 public static void main(String[] args) {
        int[] arr = {1, 2, 3};
        func(arr);
        System.out.println("arr[0] = " + arr[0]);
    }
    public static void func(int[] a) {
        a[0] = 10;
        System.out.println("a[0] = " + a[0]);
    }

運行結(jié)果:

我們可以知道,在函數(shù)內(nèi)部修改數(shù)組內(nèi)容,函數(shù)外部也發(fā)生變化。此時arr是一個“引用”。當(dāng)arr傳參時,是按照引用傳參。

引用:引用相當(dāng)于一個 "別名", 也可以理解成一個指針. 創(chuàng)建一個引用只是相當(dāng)于創(chuàng)建了一個很小的變量, 這個變量保存了一個整數(shù), 這個整數(shù)表示內(nèi)存中的一個地址.

此時a相當(dāng)于接收了arr的地址,arr和a同時指向一個數(shù)組,當(dāng)a進行操作數(shù)組時,數(shù)組內(nèi)容改變,所以arr[0]和a[0]打印結(jié)果一樣。

數(shù)組的練習(xí)

數(shù)組拷貝

第一種方法:用for循環(huán)遍歷數(shù)組拷貝

    public static int[] copyArr(int[] arr) {
        int[] ret = new int[arr.length];
        for(int i = 0; i < arr.length; i++) {
            ret[i] = arr[i];
        }
        return ret;
    }
    public static void main(String[] args) {
        int[] arr={1,2,3,4,5,6};
        int[] ret=copyArr(arr);
        System.out.println(Arrays.toString(arr));
        System.out.println(Arrays.toString(ret));
    }

運行結(jié)果:

第二種方法:

Arrays.copyOf-->庫里面的數(shù)組拷貝函數(shù)

Arrays.copeOf(數(shù)組名,數(shù)組長度)

舉個例子:

 public static void main(String[] args) {
        int[] arr={1,2,3,4,5,6};
        int[] ret=Arrays.copyOf(arr,arr.length);
        System.out.println(Arrays.toString(arr));
        System.out.println(Arrays.toString(ret));
    }

運行結(jié)果:

第三種方法:

拷貝部分元素-->Arrays.copyRange

Arrays.copyRange(數(shù)組名,拷貝開始下標(biāo),拷貝結(jié)束下標(biāo));

(開始拷貝下標(biāo)和結(jié)束下標(biāo)是左閉右開?。?/p>

舉個例子:

 public static void main(String[] args) {
        int[] arr={1,2,3,4,5,6};
        int[] ret=Arrays.copyOfRange(arr,2,5);
        System.out.println(Arrays.toString(arr));
        System.out.println(Arrays.toString(ret));
    }

運行結(jié)果:

查找數(shù)組中的指定元素(二分查找)

 public static int binarySearch(int[] arr,int x) {
        int left=0;
        int right=arr.length-1;
        while(left<right){
            int mid=(left+right)/2;
            if(arr[mid]>x){
                right=mid;
            }
            else if(arr[mid]<x){
                left=mid;
            }
            else{
                return mid;
            }
        }
        return -1;
    }
    public static void main(String[] args) {
        int[] arr={1,3,5,7,9};
        int i=binarySearch(arr,5);
        System.out.println("找到了下標(biāo)是:"+i);
    }

判斷數(shù)組是否有序

public static void main(String[] args) {
        int[] arr={1,2,5,3,4,6};
        System.out.println(bonisOrder(arr));
    }
    public static boolean bonisOrder(int[] arr) {
        for (int i = 0; i < arr.length-1; i++) {
            if(arr[i]>arr[i+1]){
                return false;
            }
        }
        return true;
    }

數(shù)組排序(冒泡排序)

public static void bubbleSort(int[] arr) {
        for (int i = 0; i < arr.length-1; i++) {
            for (int j = 0; j <arr.length-i-1 ; j++) {
                if(arr[j]>arr[j+1]){
                    int tmp=arr[j];
                    arr[j]=arr[j+1];
                    arr[j+1]=tmp;
                }
            }
        }
    }
    public static void main(String[] args) {
        int[] arr= {1,6,3,2,7};
        bubbleSort(arr);
        for(int x:arr){
            System.out.print(x+" ");
        }
    }

數(shù)組逆序

設(shè)定兩個下標(biāo) , 分別指向第一個元素和最后一個元素 . 交換兩個位置的元素。 然后讓前一個下標(biāo)自增 , 后一個下標(biāo)自減 , 循環(huán)繼續(xù)即可。

public class TsetModer {
    public static void main(String[] args) {
        int[] arr = {1, 2, 3, 4};
        reverse(arr);
        System.out.println(Arrays.toString(arr));
    }
    public static void reverse(int[] arr) {
        int left = 0;
        int right =arr.length - 1;
        while(left < right) {
            int tmp = arr[left];
            arr[left] = arr[right];
            arr[right] = tmp;
            left++;
            right--;
        }
    }

二維數(shù)組

二維數(shù)組本質(zhì)上也就是一維數(shù)組 , 只不過每個元素又是一個一維數(shù)組。

基本語法:

數(shù)據(jù)類型 [][] 數(shù)組名稱 = new 數(shù)據(jù)類型 [ 行數(shù) ][ 列數(shù) ] { 初始化數(shù)據(jù) };

看個例子:

public static void main(String[] args) {
        int[][] arr = { {1, 2, 3}, {5, 6, 7, 8}, {9, 10, 11, 12} };
        for (int row = 0; row < arr.length; row++) {
            for (int col = 0; col < arr[row].length; col++) {
                System.out.printf("%d\t", arr[row][col]);
            }
            System.out.println("");
        }
    }

這時候我們可以看到定義了一個三行四列的二位數(shù)組arr,但是第0行第3個元素沒有給元素,在C語言中默認為0,但是在Java中默認為null。

null 的作用類似于 C 語言中的 NULL (空指針), 都是表示一個無效的內(nèi)存位置. 因此不能對這個內(nèi)存進行任何讀寫操作。一旦嘗試讀寫, 就會拋出 NullPointerException。

小結(jié)

以上就是Java中數(shù)組的使用,有很多地方跟C語言中數(shù)組用法差不多。如果有什么不正確的地方,請大家盡管提出來,大家一起學(xué)習(xí)學(xué)習(xí)

到此這篇關(guān)于Java超細致講解數(shù)組的使用的文章就介紹到這了,更多相關(guān)Java數(shù)組內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java基于servlet編寫上傳下載功能 類似文件服務(wù)器

    java基于servlet編寫上傳下載功能 類似文件服務(wù)器

    這篇文章主要為大家詳細介紹了java基于servlet編寫上傳下載功能,類似文件服務(wù)器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-07-07
  • Java中字符串String的+和+=及循環(huán)操作String原理詳解

    Java中字符串String的+和+=及循環(huán)操作String原理詳解

    Java編譯器在編譯時對String的+和+=操作會創(chuàng)建StringBuilder對象來進行字符串的拼接,下面這篇文章主要給大家介紹了關(guān)于Java中字符串String的+和+=及循環(huán)操作String原理的相關(guān)資料,需要的朋友可以參考下
    2023-01-01
  • 使用Vert.x Maven插件快速創(chuàng)建項目的方法

    使用Vert.x Maven插件快速創(chuàng)建項目的方法

    這篇文章主要介紹了使用Vert.x Maven插件快速創(chuàng)建項目的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • ActiveMQ安裝及部署教程圖解

    ActiveMQ安裝及部署教程圖解

    這篇文章主要介紹了ActiveMQ安裝及部署教程圖解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07
  • Kotlin基礎(chǔ)教程之?dāng)?shù)據(jù)類型

    Kotlin基礎(chǔ)教程之?dāng)?shù)據(jù)類型

    這篇文章主要介紹了Kotlin基礎(chǔ)教程之?dāng)?shù)據(jù)類型的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • Java加解密工具類源碼示例

    Java加解密工具類源碼示例

    最近在項目中接觸到了數(shù)據(jù)加解密的業(yè)務(wù),數(shù)據(jù)加密技術(shù)是網(wǎng)絡(luò)中最基本的安全技術(shù),這篇文章主要給大家介紹了關(guān)于Java加解密工具類源碼的相關(guān)資料,需要的朋友可以參考下
    2023-11-11
  • 將java程序打成jar包在cmd命令行下執(zhí)行的方法

    將java程序打成jar包在cmd命令行下執(zhí)行的方法

    這篇文章主要給大家介紹了關(guān)于將java程序打成jar包在cmd命令行下執(zhí)行的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01
  • Java語言字典序排序算法解析及代碼示例

    Java語言字典序排序算法解析及代碼示例

    這篇文章主要介紹了Java語言字典序排序算法解析及代碼示例,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • Java?9?中的模塊Module系統(tǒng)

    Java?9?中的模塊Module系統(tǒng)

    Java?9?引入的模塊是在Java包(package)的基礎(chǔ)上又引入的一個新的抽象層,基于package這一點很重要,這里需要強調(diào)一下,接下來通過本文給大家介紹Java?9?中的模塊Module系統(tǒng),感興趣的朋友一起看看吧
    2022-03-03
  • Java單例模式繼承覆蓋多態(tài)原理詳解

    Java單例模式繼承覆蓋多態(tài)原理詳解

    這篇文章主要介紹了Java單例模式繼承覆蓋多態(tài)原理詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-09-09

最新評論