ホームページ > Java > &#&チュートリアル > カスタム クラスを使用して Java で配列をカプセル化し、データ操作を実装する方法

カスタム クラスを使用して Java で配列をカプセル化し、データ操作を実装する方法

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2023-04-19 11:10:04
転載
1258 人が閲覧しました

基本的なデータ ストレージ構造として、配列は広く使用されています。配列は、連続メモリ空間を使用して、固定長同じデータ型を格納するデータ構造です。データ構造は言語に依存せず、配列関連の操作には Java が使用されます。配列のインデックスは 0 から始まります。

カスタム クラスを使用して Java で配列をカプセル化し、データ操作を実装する方法

配列の初期化

データを作成するには 2 つの方法があります。1 つは、最初に固定長データを宣言してから、配列に値を割り当てる方法です。 . もう 1 つは、 1 つ目は直接代入です。

最初の型:

数据类型[] 数组名称 = new 数据类型[长度];
ログイン後にコピー

ここの [] マークは配列を宣言します。この [] は、データ型の後に配置するだけでなく、データ型の後ろに配置することもできます。名詞の後でも効果は同じです。長さ 2 の型 long の配列を宣言し、値を割り当てた場合:

long[] arr = new long[2];
arr[0] = 1;
arr[1] = 2;
ログイン後にコピー

2 番目の :

数据类型[] 数组名称 = {元素1,元素2, ...};
ログイン後にコピー

このように、配列の初期化時に直接値が代入され、配列の長さは要素数によって決まります。

2 つのカスタム クラスは配列をカプセル化してデータ操作を実装します

public class MyArray {

    // 自定义数组    private long[] arr;
    // 有效数据长度    private int element;

    public MyArray(){
        arr = new long[9];
    }

    public MyArray(int maxsize){
        arr = new long[maxsize];
    }
    /**
     * 显示数组元素
     */    public void display(){
        System.out.print("[");
        for (int i = 0; i < element; i++) {
            System.out.print(arr[i]+" ");
        }
        System.out.print("]");
    }
}
ログイン後にコピー

2.1 要素の追加

配列はデータを格納するために連続メモリ領域を使用するため、追加されるたびに要素を追加します現在の配列の最後の要素に追加します。要素は一度に追加できるため、複雑さは O(1) です。#9 の長さの配列を定義すると、配列にはすでに 2 つの要素があります

カスタム クラスを使用して Java で配列をカプセル化し、データ操作を実装する方法

public void add(long value){
    arr[element] = value;
    element++;
}
ログイン後にコピー

2.2 値に基づいて要素の位置をクエリする

この検索方法は、線形検索とも呼ばれます。値は要素をループして対応する位置を取得します。理論上、要素のクエリには平均で N/2 回かかるため、その複雑さは O(N) です。

public int find(long value){
    int i;
    for (i = 0; i < element; i++) {
        if(value == arr[i]){
            break;
        }
    }
    if(i == element){
        return -1;
    }else {
        return i;
    }
}
ログイン後にコピー

2.3 インデックスに従って要素をクエリする

インデックスに従って要素を検索する、つまり、対応する位置の要素を取得する場合、計算量は O(1) です。

public long get(int index){
    if(index >= element || index < 0){
        throw new ArrayIndexOutOfBoundsException();
    }else {
        return arr[index];
    }
}
ログイン後にコピー

2.4 インデックスに基づいて要素を削除する

インデックスに対応する要素を削除した後、インデックスの後のすべての要素を 1 つ前に移動する必要があります。インデックス 2 の要素を削除したい場合は、次のようにします。

カスタム クラスを使用して Java で配列をカプセル化し、データ操作を実装する方法

# 理論的には、要素を平均して削除するには、N/2 回移動する必要があるため、時間計算量も O(N) です。

public void delete(int index){
    if(index >= element || index < 0){
        throw new ArrayIndexOutOfBoundsException();
    }else {
        for (int i = index; i < element; i++) {
            arr[index] = arr[index+1];
        }
        element --;
    }
}
ログイン後にコピー

2.5 要素の変更

特定の位置の要素を変更し、インデックスに従って対応する要素を直接変更するので、その時間計算量は O(1) です。

public void change(int index,long newValue){
    if(index >= element || index < 0){
        throw new ArrayIndexOutOfBoundsException();
    }else {
        arr[index] = newValue;
    }
}
ログイン後にコピー

3 順序付き配列

順序付き配列は特別なタイプの配列であり、順序付き配列内の要素は特定の順序で配置されます。

3.1 要素の追加

要素を追加する場合は、一定の位置に順番に要素を追加していきます。次のように、要素 33 を配列に追加します。

カスタム クラスを使用して Java で配列をカプセル化し、データ操作を実装する方法

まず、インデックス 3 の要素をインデックス 4 に移動し、次にインデックス 2 の要素をインデックス 3 に移動し、最後にインデックス 2 に 33 を加算します。理論的には、要素の挿入には N/2 個の要素を移動する必要があるため、時間計算量は O(N) になります。

public void add(long value){
    int i;
    for (i = 0; i < element; i++) {
        if(arr[i]>value){
            break;
        }
    }

    for (int j = element; j > i; j--){
        arr[j] = arr[j-1];
    }
    arr[i] = value;
    element++;
}
ログイン後にコピー

3.2 要素に基づいてインデックスをクエリする二分法

順序なし配列で、関連する要素を見つけるには線形法を使用します。線形法とは、インデックスに従って 1 つずつ検索することです。ソートされた配列では、二分法を使用して要素を見つけることができます。二分法とは、配列を中央から 2 つに分割し、その要素がどちらの配列にあるかを判断し、この操作を繰り返すことを意味します。

8 要素を持つ配列があるとします。配列の内容は 0 ~ 7 の順序付けられたシーケンスです。要素 5 を見つけるには、要素 5 を 0 ~ 3 と 4 に分割します。初回は -7 2 つの配列、次に 4-7 を 2 つの配列 4-5 と 6-7 に分割し、最後に 4-5 を 4 と 5 に分割して特定の要素をクエリする このように、3 回分割した後、8 の配列内の特定の要素の複雑さは O(logN) の長さをクエリできます (コンピューターにおける logN の底は通常 2 を指します。これは、2 の累乗が n に等しいことを意味します)。

public int search(long value){
    // 中间值    int middle = 0;
    // 最小值    int low = 0;
    // 最大值    int pow = element;
    while (true){
        middle = (low + pow) / 2;
        if(arr[middle] == value){
            return middle;
        }else if (low > pow){
            return -1;
        }else{
            if(arr[middle] > value){
                pow = middle - 1;
            }else{
                low = middle + 1;
            }
        }
    }
}
ログイン後にコピー

4 つのまとめ

複雑さが低いほどアルゴリズムが優れていることを意味するため、O(1) > O(logN) > O(N) > O(N^2) となります。 。

#O(logN)#順序なし配列の挿入順序付き配列の挿入順序なし配列の削除#順序付き配列の削除
アルゴリズム 複雑さ
線形探索 O (N)
二分探索
O( 1)
O(N)
O( N)
O(N)
    ##順序なし配列挿入は高速ですが、検索と削除は低速です。
  1. 順序付けされた配列の検索は高速ですが、挿入と削除は低速です

以上がカスタム クラスを使用して Java で配列をカプセル化し、データ操作を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:yisu.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
ヘルプ: JAVA 暗号化データ PHP 復号化
から 1970-01-01 08:00:00
0
0
0
JAVAをインストールする
から 1970-01-01 08:00:00
0
0
0
Javaをインストールできません
から 1970-01-01 08:00:00
0
0
0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート