ホームページ >Java >&#&チュートリアル >Java の基礎から実践的な応用まで: アルゴリズムとデータ構造の実践的な応用
アルゴリズムは問題を解決するための一連の手順であり、データ構造はデータを順序立てて保存するための体系的な方法であり、効率的なプログラムを作成するために不可欠です。一般的なタイプのアルゴリズムには、検索、並べ替え、グラフ理論アルゴリズムなどがあります。データ構造タイプには、配列、リンク リスト、スタック、キュー、セットなどがあります。実際のアプリケーションでは、スタックを使用してブラケット マッチング問題を解決し、キューを使用してプロデューサーとコンシューマーの問題を解決できます。
Javaの基礎から実践的な応用まで: アルゴリズムとデータ構造の実践的な応用
アルゴリズムとデータ構造とは何ですか?
アルゴリズムは特定の問題を解決するためのステップの集合であり、データ構造はデータを保存および整理する体系的な方法です。これらは効率的で強力なプログラムを作成するために不可欠です。
一般的なアルゴリズムの種類
一般的なデータ構造タイプ
実際のケース:
スタックを使用して括弧一致の問題を解決する
丸括弧、角括弧、中括弧など、さまざまな種類の括弧を含む文字列を考えてみましょう。文字列が有効かどうか (すべての括弧がペアになっていて、正しく一致しているかどうか) を確認するには、スタックを使用します。
Java コード:
import java.util.Stack; public class BracketMatcher { public static boolean isBalanced(String str) { Stack<Character> stack = new Stack<>(); for (char c : str.toCharArray()) { if (isOpen(c)) { stack.push(c); } else if (isClose(c)) { if (stack.isEmpty() || !isMatch(stack.pop(), c)) { return false; } } } return stack.isEmpty(); } private static boolean isOpen(char c) { return c == '(' || c == '[' || c == '{'; } private static boolean isClose(char c) { return c == ')' || c == ']' || c == '}'; } private static boolean isMatch(char open, char close) { return (open == '(' && close == ')') || (open == '[' && close == ']') || (open == '{' && close == '}'); } public static void main(String[] args) { String str1 = "()[]{}"; String str2 = "([)]"; System.out.println(isBalanced(str1)); // true System.out.println(isBalanced(str2)); // false } }
プロデューサーとコンシューマーの問題を解決するためのキューの使用
キューを共有するプロデューサーとコンシューマーのスレッドを考えてみましょう。プロデューサ スレッドはキューに項目を追加し、コンシューマ スレッドはキューから項目を削除します。スレッドの安全性を確保し、競合状態を回避するために、キューを使用できます。
Java コード:
import java.util.concurrent.ArrayBlockingQueue; public class ProducerConsumer { private ArrayBlockingQueue<Integer> queue; public ProducerConsumer(int capacity) { queue = new ArrayBlockingQueue<>(capacity); } // 生产者线程 public void produce(int item) { try { queue.put(item); } catch (InterruptedException e) { e.printStackTrace(); } } // 消费者线程 public int consume() { try { return queue.take(); } catch (InterruptedException e) { e.printStackTrace(); return -1; // 作为错误标志 } } public static void main(String[] args) { ProducerConsumer pc = new ProducerConsumer(5); new Thread(() -> { for (int i = 0; i < 10; i++) { pc.produce(i); } }).start(); new Thread(() -> { while (true) { int item = pc.consume(); if (item == -1) { break; // 队列为空 } System.out.println("Consumed: " + item); } }).start(); } }
以上がJava の基礎から実践的な応用まで: アルゴリズムとデータ構造の実践的な応用の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。