Javaを使用して最短パスアルゴリズムを実装する方法
Java を使用して最短パス アルゴリズムを実装する方法
概要:
最短パス アルゴリズムは、ネットワーク分野におけるグラフ理論の重要な応用です。ルート検索、地図ナビゲーションなど、すべて幅広い用途に使用できます。この記事では、Java を使用して最短パス アルゴリズムを実装する方法を学び、具体的なコード例を示します。
アルゴリズムのアイデア:
最短経路アルゴリズムを実装するには多くの方法がありますが、その中で最も有名な 2 つのアルゴリズムは、ダイクストラ アルゴリズムと A* アルゴリズムです。ここでは、ダイクストラのアルゴリズムの実装に焦点を当てます。
ダイクストラのアルゴリズムの基本的な考え方は、開始ノードから開始して、他のすべてのノードへの最短パスを順番に計算することです。具体的なアルゴリズムのプロセスは次のとおりです:
- 開始ノードから他のノードまでの最短距離を格納する距離配列 dist を作成します。最初に、開始ノードの距離を 0 に設定し、他のノード。無限大に設定します。
- 最短パスが計算されたノードを保存するために訪問されたコレクションを作成します。
- すべてのノードが訪問されるまで、次の手順を繰り返します:
a. 距離配列 dist 内の開始ノードに最も近い未訪問のノードを見つけ、そのノードを訪問済みセットに追加します。
b. 距離配列 dist を更新します。現在のノードを経由して他のノードへのより短いパスが見つかった場合は、ノードの距離を更新します。 - 最終的な距離配列 dist に従って、開始ノードから他のノードまでの最短経路を求めることができます。
コードの実装:
次は、Java を使用してダイクストラ アルゴリズムを実装するコード例です:
import java.util.*; public class DijkstraAlgorithm { public static void dijkstra(int[][] graph, int start) { int numNodes = graph.length; int[] dist = new int[numNodes]; boolean[] visited = new boolean[numNodes]; Arrays.fill(dist, Integer.MAX_VALUE); dist[start] = 0; for (int i = 0; i < numNodes; i++) { int minDist = Integer.MAX_VALUE; int minIndex = -1; for (int j = 0; j < numNodes; j++) { if (!visited[j] && dist[j] < minDist) { minDist = dist[j]; minIndex = j; } } visited[minIndex] = true; for (int j = 0; j < numNodes; j++) { if (!visited[j] && graph[minIndex][j] != 0 && dist[minIndex] != Integer.MAX_VALUE && dist[minIndex] + graph[minIndex][j] < dist[j]) { dist[j] = dist[minIndex] + graph[minIndex][j]; } } } printResult(dist); } public static void printResult(int[] dist) { int numNodes = dist.length; System.out.println("最短路径距离:"); for (int i = 0; i < numNodes; i++) { System.out.println("节点 " + i + " 的最短路径距离是 " + dist[i]); } } public static void main(String[] args) { int[][] graph = { { 0, 4, 0, 0, 0, 0, 0, 8, 0 }, { 4, 0, 8, 0, 0, 0, 0, 11, 0 }, { 0, 8, 0, 7, 0, 4, 0, 0, 2 }, { 0, 0, 7, 0, 9, 14, 0, 0, 0 }, { 0, 0, 0, 9, 0, 10, 0, 0, 0 }, { 0, 0, 4, 14, 10, 0, 2, 0, 0 }, { 0, 0, 0, 0, 0, 2, 0, 1, 6 }, { 8, 11, 0, 0, 0, 0, 1, 0, 7 }, { 0, 0, 2, 0, 0, 0, 6, 7, 0 } }; int startNode = 0; dijkstra(graph, startNode); } }
上記のコードでは、DijkstraAlgorithm という名前のクラスを作成しました。ダイクストラ法は、ダイクストラ アルゴリズムの実装の重要な部分です。 main メソッドでは、グラフの隣接行列を表す 9x9 の 2 次元配列グラフを定義し、開始ノードを 0 に指定します。ダイクストラ法を呼び出すことで、開始ノードから他のノードまでの最短パス距離を取得できます。
概要:
Java を使用して最短パス アルゴリズムを実装することは、実用的な応用価値を持つ非常に興味深いタスクです。ダイクストラアルゴリズムの基本的な考え方と具体的な実装コードを学ぶことで、最短経路アルゴリズムの原理をより深く理解し、実際のプロジェクトに柔軟に適用することができます。この記事で提供されているコード例が、最短パス アルゴリズムの理解と使用に役立つことを願っています。
以上がJavaを使用して最短パスアルゴリズムを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Java の Weka へのガイド。ここでは、weka java の概要、使い方、プラットフォームの種類、利点について例を交えて説明します。

この記事では、Java Spring の面接で最もよく聞かれる質問とその詳細な回答をまとめました。面接を突破できるように。

Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです

Java での日付までのタイムスタンプに関するガイド。ここでは、Java でタイムスタンプを日付に変換する方法とその概要について、例とともに説明します。

カプセルは3次元の幾何学的図形で、両端にシリンダーと半球で構成されています。カプセルの体積は、シリンダーの体積と両端に半球の体積を追加することで計算できます。このチュートリアルでは、さまざまな方法を使用して、Javaの特定のカプセルの体積を計算する方法について説明します。 カプセルボリュームフォーミュラ カプセルボリュームの式は次のとおりです。 カプセル体積=円筒形の体積2つの半球体積 で、 R:半球の半径。 H:シリンダーの高さ(半球を除く)。 例1 入力 RADIUS = 5ユニット 高さ= 10単位 出力 ボリューム= 1570.8立方ユニット 説明する 式を使用してボリュームを計算します。 ボリューム=π×R2×H(4

Spring Bootは、Java開発に革命をもたらす堅牢でスケーラブルな、生産対応のJavaアプリケーションの作成を簡素化します。 スプリングエコシステムに固有の「構成に関する慣習」アプローチは、手動のセットアップを最小化します。
