検索
ホームページJava&#&チュートリアルJavaで元の配列をスパース配列に変換する方法

1. それは何ですか?

たとえば、11 * 11 のバックギャモン ボードがあり、プログラムを使用してそれをシミュレートしたい場合、それは 2 次元配列でなければなりません。次に、黒石を表すのに 1 を使用し、白石を表すのに 2 を使用します。チェス盤上に黒石と白石が 1 つずつしかない場合、この 2 次元配列には 1 と 2 が 1 つだけあり、残りは無意味です。チェスの駒を表さない 0 は次のようになります。

0 0 0 0 0 0 0 0 0 0 0 
0 0 0 0 1 0 0 0 0 0 0
0 0 0 2 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
……

配列内のほとんどの要素が 0 であるか、同じ値を持つ場合、スパース配列を使用して配列を保存できます。なぜこれを行うのでしょうか?スペースを節約できるからです。

2. 使い方は?

  • 元の配列の行数と列数、および異なる値の数を記録します

  • 行と列を配置します。異なる値と値を持つ要素の列が小規模配列に記録され、この小規模配列はスパース配列

3 と呼ばれます。

#現在の状況は次のとおりです。 元の 6 * 7 の配列:

0   0   0   22   0   0   15
0   11  0   0    0   17   0
0   0   0  -6    0   0    0
0   0   0   0    0   39   0
91  0   0   0    0   0    0
0   0   28  0    0   0    0
まず、疎配列の最初の行と最初の列に、要素配列が何行あるかを記録します。最初の行と 2 番目の列は、元の配列が何列であるかを記録します。最初の行と最初の列は、元の配列に異なる値がいくつあるか (0 を除く) を記録します。したがって、スパース配列の 1 行は次のようになります。

行    列    值
6     7     8
スパース配列の 2 行目から開始して、各行には、元の配列内の 0 以外の値の行、列、および値のサイズが記録されます。たとえば、2 行目に元の配列の行、列、および値 22 を記録する場合、スパース配列の 2 行目は次のようになります。

行    列    值
0     3     22
次に、このメソッドを使用して 15、11 を記録します。 、17、-6、39、91、28 の関連情報が含まれるため、元の配列から最終的に変換されたスパース配列は次のようになります。

行    列    值
6     7     8
0     3     22
0     6     15
1     1     11
1     5     17
2     3     -6
3     5     39
4     0     91
5     2     28
これにより、6 * 7 配列が 9 * 3 配列に変換され、圧縮が実現されます。効果 。

4. 元の配列とスパース配列を変換するためのアイデア:

元の配列をスパース配列に変換する:

  • 2 つをトラバースします。次元 配列は有効な配列の数を取得します。 count;

  • count に基づいてスパース配列を作成できます。

    int[count 1][3];

  • 有効な配列をスパース配列に保存します

スパース配列を変換します元の配列へ:

  • 疎配列の最初の行を読み取ります。配列の最初の行に基づいて、元の配列の行数と列数を知ることができ、元の配列;

  • スパース配列の後の数行の配列を読み取り、それを元の配列に代入します

5。練習:

public class SparseArray {
    public static void main(String[] args){
        // 创建一个 11 * 11的原始数组
        int[][] arr1 = new int[11][11];
        arr1[1][2] = 1;
        arr1[2][3] = 2;

        // 原始数组转稀疏数组
        // 1. 遍历,得到非0数据的个数以及所在的行列
        int count = 0;
        Map<string> map = new HashMap();
        for (int i = 0; i </string>
上記のコードは、元の配列と疎な配列の間の相互変換を実現します. 疎な配列を柔軟に使用することで、実行メモリを節約し、プログラムのパフォーマンスを向上させることができます。

以上がJavaで元の配列をスパース配列に変換する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事は亿速云で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール