【數據結構】

一、架構梳理

  • 線性(1:1)

    • 線性表

      • 順序存儲 –>?arr
      • 鏈式存儲 –> 指針 (有頭,無頭

        有頭是指有一個不存數據的頭,始終作為這個鏈表的起點。

        會更加簡單,無頭的話,更改首部節點會麻煩。

        頭節點不僅可以作為起點,還可以作為存儲信息的倉庫,因為頭節點只有*next是必須的。

        • 單鏈表
          • 循環
          • 不循環
        • 雙向鏈表

          lib四個版本,第一個最基礎完善,第二個改成了變長結構體,第三個在第二個的基礎上封裝了函數指針,第四個在第二個的基礎上隱藏了數據結構,只暴露接口。

          學到這里可以去讀一下內核有關list的實現,主要都是宏和內聯函數。

          • 循環
          • 不循環
    • 隊列

      練習:

      1. 表達式計算

      2. 球鐘算法
        三個棧,1h,5min,1min。27個球,過了多久隊列里又是1到27的順序。

  • 樹狀(1:N)

    遞歸遞歸非遞歸

    • 深度:層數

    • 度:子樹的個數

    • 葉子:邊緣節點

    • 孩子:與父節點對應

    • 兄弟:相同父節點

    • 堂兄弟:相同爺節點

    • 二叉樹:

      • 滿二叉樹:深度為k且節點為2^k-1的二叉樹
      • 完全二叉樹:一顆二叉樹,只有倒數兩層可以存在不滿兩個孩子的節點,且單個孩子時只能是左孩子
    • 存儲:

      • 順序:直觀,但是浪費空間
        滿二叉樹:父節點n,左孩子2n,右孩子2n+1
      • 鏈式:靈活,空間利用率高
    • 遍歷

      先加中,或者,中加后,都可以逆推出樹。先加后不行。

      • 按行
      • 先序(根,左,右)
      • 中序(左,根,右)
      • 后序(左,右,根)
    • 平衡:

      有很多種條件判定。

      這棵樹的左右子樹個數差值為1。

    • 廣義表

      ( root ( left ) ( right) ),進行嵌套。

    • 搜索樹

      空間換時間,查找是**o(1)**。

      課后作業:詞頻統計

  • 圖(N:M)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/81124.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/81124.shtml
英文地址,請注明出處:http://en.pswp.cn/web/81124.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

UML學習指南:從零入門到實戰應用

為零基礎學習者設計的UML技術文檔,旨在通過詳細解釋和實際案例,從零開始掌握UML。 UML學習指南:從零入門到實戰應用 目錄 引言:UML是什么?為什么學習UML? 1.1 什么是UML?1.2 為什么我們需要UM…

Matlab實戰訓練項目推薦

以下是一系列適合不同技能水平的 MATLAB 實戰訓練項目,涵蓋基礎編程、數據分析、信號處理、圖像處理、控制系統、機器學習等領域。這些項目可幫助你鞏固理論知識并提升實際應用能力。 一、基礎項目(適合初學者) 矩陣運算與可視化 目標&#x…

從零開始:Python語言進階之異常處理

一、認識異常:程序運行中的“意外事件” 在編寫Python程序時,即使代碼語法完全正確,運行過程中也可能遭遇各種意外情況。這些意外被稱為異常,它們會打斷程序的正常執行流程。例如,當我們嘗試打開一個不存在的文件、用0…

Groovy:Java 的簡潔版

Groovy 是一種 動態、面向對象的編程語言,運行在 Java 虛擬機(JVM)上,并與 Java 高度兼容。你可以把它理解為“Java 的簡潔版 動態特性 腳本語言的靈活性”。 🧠 Groovy 的核心特點 特性說明? 與 Java 高度兼容可以…

生成模型——PixelRNN與PixelCNN

一、PixelRNN PixelRNN 是一種基于循環神經網絡(RNN)的像素級生成模型,通過逐個像素地生成圖像來構建完整的圖像,其核心思想是將圖像中的像素視為序列,并利用 RNN 的能力來捕捉像素之間的依賴關系。 序列生成&#xf…

每日算法刷題Day14 5.24:leetcode不定長滑動窗口求子數組個數越長越合法4道題,用時1h20min

3. 3325.字符至少出現K次的子字符串I(中等,學習優化) 3325. 字符至少出現 K 次的子字符串 I - 力扣(LeetCode) 思想 1.給你一個字符串 s 和一個整數 k,在 s 的所有子字符串中,請你統計并返回 至少有一個 字符 至少…

怎么判斷一個Android APP使用了Capacitor這個跨端框架

要判斷一個 Android 應用是否使用了 Capacitor 跨端框架,可以通過以下方法逐步驗證: 一、安裝包結構分析 1. 解壓 APK 將 .apk 文件重命名為 .zip 并解壓,檢查以下特征文件: ? assets/public/ 目錄: Capacitor 的核心…

Vue3性能優化: 大規模列表渲染解決方案

# Vue3性能優化: 大規模列表渲染解決方案 一、背景與挑戰 背景 在大規模應用中,Vue3的列表渲染性能一直是開發者關注的焦點。大規模列表渲染往往會導致卡頓、內存占用過高等問題,影響用戶體驗和系統整體性能。 挑戰 渲染大規模列表時,DOM操作…

數據倉庫,掃描量

有五種通用技術用于限制數據的掃描量,正如圖3 - 4所示。第一種技術是掃描那些被打上時戳的數據。當一個應用對記錄的最近一次變化或更改打上時戳時,數據倉庫掃描就能夠很有效地進行,因為日期不相符的數據就接觸不到了。然而,目前的…

反射在spring boot自動配置的應用

目錄 一,背景 二,知識回顧 2.1 理解使用反射技術,讀取配置文件創建目標對象(成員變量,方法,構造方法等) 三,springboot自動配置 3.1 反射在自動配置中的工作流程 3.2 瀏覽源碼…

機器學習 Day1

機器學習概述 機器學習與人工智能、深度學習關系什么是機器學習數據集算法 機器學習與人工智能、深度學習關系 什么是機器學習 機器學習是從數據中自動分析獲取模型,并利用模型對未知數據進行預測。 直觀理解: 所以是從歷史數據中獲取規律,那么這些歷…

Disruptor—2.并發編程相關簡介

大綱 1.并發類容器 2.volatile關鍵字與內存分析 3.Atomic系列類與UnSafe類 4.JUC常用工具類 5.AQS各種鎖與架構核心 6.線程池的最佳使用指南 1.并發類容器 (1)ConcurrentMap (2)CopyOnWrite容器 (3)ArrayBlockingQueue (4)LinkedBlockingQueue (5)SynchronousQueue …

開盤啦 APP 抓包 逆向分析

聲明: 本文章中所有內容僅供學習交流使用,不用于其他任何目的,抓包內容、敏感網址、數據接口等均已做脫敏處理,嚴禁用于商業用途和非法用途,否則由此產生的一切后果均與作者無關! 抓包 這是一個記錄貼。 這個APP是數…

YOLOv8損失函數代碼詳解(示例展示數據變換過程)

本文將展示YOLOv8中損失函數計算的完整代碼解析,注釋中提供了詳盡的解釋,并結合示例演示了數據維度的轉換,以幫助更好地理解。 YOLOv8的損失函數計算代碼位于ultralytics/utils/loss.py文件中(如下所示),我…

微信小程序調用藍牙API “wx.writeBLECharacteristicValue()“ 報 errCode: 10008 的解決方案

1、問題現象 問題:在開發微信小程序藍牙通信功能時,常常會遇到莫名其妙的錯誤,查閱官方文檔可能也無法找到答案。如在寫入藍牙數據時,報了這樣的錯誤: {errno: 1500104, errCode: 10008, errMsg: "writeBLECharacteristicValue:fail:system error, status: UNKNOW…

軟考 UML中的 用例圖 的泛化 包含 擴展 關系

用例圖的泛化、擴展和包含 - ^_^肥仔John - 博客園

MyBatis-Plus的自帶分頁方法生成的SQL失敗:The error occurred while setting parameters

1、error描述 數據庫是postgres,Java使用mybatis-plus的分頁功能,生成的分頁SQL不能正常運行。 "msg": "nested exception is org.apache.ibatis.exceptions.PersistenceException: Error querying database. Cause: com.baomidou.my…

Redis從入門到實戰 - 原理篇

一、數據結構 1. 動態字符串SDS 我們都知道Redis中保存的key是字符串,value往往是字符串或者字符串的集合。可見字符串是Redis中最常用的一種數據結構。 不過Redis沒有直接使用C語言中的字符串,因為C語言字符串存在很多問題: 獲取字符串長…

人形機器人通過觀看視頻學習人類動作的技術可行性與前景展望

摘要 本文深入探討人形機器人通過觀看視頻學習人類動作這一技術路線的正確性與深遠潛力。首先闡述該技術路線在模仿人類學習過程方面的優勢,包括對人類動作、表情、發音及情感模仿的可行性與實現路徑。接著從技術原理、大數據訓練基礎、與人類學習速度對比等角度論證…

高分辨率北半球多年凍土數據集(2000-2016)

關鍵數據集分類&#xff1a;冰凍圈數據集時間分辨率&#xff1a;10 year < x < 100 year空間分辨率&#xff1a;1km - 10km共享方式&#xff1a;開放獲取數據大小&#xff1a;339.79 MB數據時間范圍&#xff1a;2000-01-01 — 2016-12-31元數據更新時間&#xff1a;2022-…