Java資料結構與演算法:實戰案例詳解
資料結構和演算法是程式高效性的關鍵要素。 Java 中常用的資料結構包括陣列、鍊錶、堆疊和二元樹。常見演算法包括快速排序和二分查找。本文透過實戰案例,深入淺出地解釋這些概念:陣列:連續儲存同類型元素,如學生成績。鍊錶:元素透過指針鏈接,如模擬隊列。堆疊:遵循 LIFO 原則,如追蹤函數呼叫。二元樹:樹形資料結構,如檔案系統目錄。快速排序:分治策略,將陣列分成兩部分分別排序。二分查找:有序數組進行二分查找,縮小搜尋範圍。
Java 資料結構與演算法:實戰案例詳解
引言
數據結構和演算法是電腦科學的基礎,它們決定了程式的效率和穩健性。本文將透過一系列實戰案例,深入淺出地講解 Java 中常用的資料結構與演算法。
陣列
定義:連續記憶體空間中儲存同類型元素的集合。
實戰案例:儲存學生成績
int[] scores = {90, 85, 78, 95, 82};
鍊錶
定義:元素透過指標連結的線性資料結構。
實戰案例:模擬佇列
class Node { int value; Node next; } class Queue { Node head; Node tail; public void enqueue(int value) { Node newNode = new Node(); newNode.value = value; if (head == null) { head = newNode; tail = newNode; } else { tail.next = newNode; tail = newNode; } } public int dequeue() { if (head == null) { throw new RuntimeException("Queue is empty"); } int value = head.value; head = head.next; if (head == null) { tail = null; } return value; } }
堆疊
定義:遵循後進先出( LIFO) 原則的線性資料結構。
實戰案例:追蹤函數呼叫
class Stack<T> { private List<T> elements = new ArrayList<>(); public void push(T element) { elements.add(element); } public T pop() { if (elements.isEmpty()) { throw new RuntimeException("Stack is empty"); } return elements.remove(elements.size() -1); } public T peek() { if (elements.isEmpty()) { throw new RuntimeException("Stack is empty"); } return elements.get(elements.size() -1); } }
二叉樹
定義:包含一個根節點和零個或多個子節點的樹狀資料結構。
實戰案例:檔案系統目錄
class TreeNode { private String name; private List<TreeNode> children; // ... 其他代码 } class FileSystem { private TreeNode root; // ... 其他代码 }
#排序演算法
快速排序
描述:分治策略,將陣列分成兩部分,分別排序,然後合併。
實戰案例:排序一組數字
public static void quickSort(int[] arr) { if (arr == null || arr.length <= 1) { return; } int pivot = arr[0]; int leftIndex = 0; int rightIndex = arr.length - 1; while (leftIndex < rightIndex) { while (arr[rightIndex] >= pivot && rightIndex > leftIndex) { rightIndex--; } arr[leftIndex] = arr[rightIndex]; while (arr[leftIndex] <= pivot && rightIndex > leftIndex) { leftIndex++; } arr[rightIndex] = arr[leftIndex]; } arr[leftIndex] = pivot; quickSort(arr, 0, leftIndex - 1); quickSort(arr, leftIndex + 1, arr.length - 1); }
找出演算法
二分查找
說明:對有序數組進行二分查找,逐級縮小搜尋範圍。
實戰案例:找出陣列中的一個元素
public static int binarySearch(int[] arr, int target) { int left = 0; int right = arr.length - 1; while (left <= right) { int mid = (left + right) / 2; if (arr[mid] == target) { return mid; } else if (arr[mid] < target) { left = mid + 1; } else { right = mid - 1; } } return -1; }
以上是Java資料結構與演算法:實戰案例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

Java 8引入了Stream API,提供了一種強大且表達力豐富的處理數據集合的方式。然而,使用Stream時,一個常見問題是:如何從forEach操作中中斷或返回? 傳統循環允許提前中斷或返回,但Stream的forEach方法並不直接支持這種方式。本文將解釋原因,並探討在Stream處理系統中實現提前終止的替代方法。 延伸閱讀: Java Stream API改進 理解Stream forEach forEach方法是一個終端操作,它對Stream中的每個元素執行一個操作。它的設計意圖是處

Java是熱門程式語言,適合初學者和經驗豐富的開發者學習。本教學從基礎概念出發,逐步深入解說進階主題。安裝Java開發工具包後,可透過建立簡單的「Hello,World!」程式來實踐程式設計。理解程式碼後,使用命令提示字元編譯並執行程序,控制台上將輸出「Hello,World!」。學習Java開啟了程式設計之旅,隨著掌握程度加深,可創建更複雜的應用程式。

膠囊是一種三維幾何圖形,由一個圓柱體和兩端各一個半球體組成。膠囊的體積可以通過將圓柱體的體積和兩端半球體的體積相加來計算。本教程將討論如何使用不同的方法在Java中計算給定膠囊的體積。 膠囊體積公式 膠囊體積的公式如下: 膠囊體積 = 圓柱體體積 兩個半球體體積 其中, r: 半球體的半徑。 h: 圓柱體的高度(不包括半球體)。 例子 1 輸入 半徑 = 5 單位 高度 = 10 單位 輸出 體積 = 1570.8 立方單位 解釋 使用公式計算體積: 體積 = π × r2 × h (4
