国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

CS-第 5 周

Apr 03, 2025 pm 11:06 PM
c語言 鍵值對 typedef

數(shù)據(jù)結(jié)構(gòu)詳解:從數(shù)組到樹,再到哈希表

本文深入探討幾種常見的數(shù)據(jù)結(jié)構(gòu),包括數(shù)組、鏈表、二叉搜索樹(BST)和哈希表,并闡述其在內(nèi)存中的組織方式及優(yōu)缺點。

信息結(jié)構(gòu)與抽象數(shù)據(jù)結(jié)構(gòu)

信息結(jié)構(gòu)指的是內(nèi)存中組織信息的方式,而抽象數(shù)據(jù)結(jié)構(gòu)則是我們概念上對這些結(jié)構(gòu)的理解。 理解抽象數(shù)據(jù)結(jié)構(gòu)有助于我們更好地在實踐中實現(xiàn)各種數(shù)據(jù)結(jié)構(gòu)。


堆棧和隊列

隊列是一種遵循FIFO(先進先出)原則的抽象數(shù)據(jù)結(jié)構(gòu),類似于排隊等候。其主要操作包括入隊(添加元素到隊列尾部)和出隊(移除隊列頭部元素)。

堆棧則遵循LIFO(后進先出)原則,如同疊盤子。其操作包括壓入(添加元素到堆棧頂部)和彈出(移除堆棧頂部元素)。


數(shù)組

數(shù)組是一種在內(nèi)存中連續(xù)存儲數(shù)據(jù)的結(jié)構(gòu)。 如下圖所示,數(shù)組在內(nèi)存中占據(jù)連續(xù)的存儲空間。

CS-第 5 周

內(nèi)存中可能存在其他程序、函數(shù)和變量,以及之前使用過的冗余數(shù)據(jù)。 如果需要向數(shù)組添加新元素,則需要重新分配內(nèi)存并復(fù)制整個數(shù)組,這會造成效率低下。

CS-第 5 周 CS-第 5 周 CS-第 5 周

預(yù)先分配過多的內(nèi)存雖然可以減少復(fù)制操作,但卻會浪費系統(tǒng)資源。因此,根據(jù)實際需求分配內(nèi)存至關(guān)重要。


鏈表

鏈表是一種強大的數(shù)據(jù)結(jié)構(gòu),它允許將位于不同內(nèi)存區(qū)域的值連接成一個列表,并支持動態(tài)擴展或縮小。

CS-第 5 周

每個節(jié)點包含兩個值:數(shù)據(jù)值和指向下一個節(jié)點的指針。最后一個節(jié)點的指針值為NULL,表示鏈表的結(jié)尾。

CS-第 5 周 CS-第 5 周

C語言中,節(jié)點可以定義如下:

typedef struct CS-第 5 周 {
    int number;
    struct CS-第 5 周 *next;
} CS-第 5 周;

以下示例展示了鏈表的創(chuàng)建過程:

CS-第 5 周 CS-第 5 周 CS-第 5 周 CS-第 5 周 CS-第 5 周 CS-第 5 周 CS-第 5 周 CS-第 5 周

鏈表的缺點包括:需要額外內(nèi)存存儲指針,以及無法通過索引直接訪問元素。


二叉搜索樹 (BST)

二叉搜索樹是一種高效存儲、搜索和檢索數(shù)據(jù)的樹形結(jié)構(gòu)。

CS-第 5 周 CS-第 5 周 CS-第 5 周

BST 的優(yōu)點在于動態(tài)性和搜索效率(O(log n)),缺點在于樹不平衡時搜索效率會下降到 O(n),并且需要額外的內(nèi)存存儲指針。


哈希表

哈希表類似于字典,包含鍵值對。 它利用哈希函數(shù)將鍵映射到數(shù)組索引,從而實現(xiàn) O(1) 的平均查找時間。

CS-第 5 周

哈希沖突(多個鍵映射到同一個索引)可以通過鏈表或其他方法解決。 哈希函數(shù)的設(shè)計對哈希表的性能至關(guān)重要。 一個簡單的哈希函數(shù)示例如下:

#include <ctype.h>

unsigned int hash(const char *word) {
    return toupper(word[0]) - 'A';
}

本文基于cs50x 2024源碼整理。

以上是CS-第 5 周的詳細內(nèi)容。更多信息請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻,版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機

Video Face Swap

Video Face Swap

使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

debian readdir如何與其他工具集成 debian readdir如何與其他工具集成 Apr 13, 2025 am 09:42 AM

Debian系統(tǒng)中的readdir函數(shù)是用于讀取目錄內(nèi)容的系統(tǒng)調(diào)用,常用于C語言編程。本文將介紹如何將readdir與其他工具集成,以增強其功能。方法一:C語言程序與管道結(jié)合首先,編寫一個C程序調(diào)用readdir函數(shù)并輸出結(jié)果:#include#include#includeintmain(intargc,char*argv[]){DIR*dir;structdirent*entry;if(argc!=2){

redis計數(shù)器怎么實現(xiàn) redis計數(shù)器怎么實現(xiàn) Apr 10, 2025 pm 10:21 PM

Redis計數(shù)器是一種使用Redis鍵值對存儲來實現(xiàn)計數(shù)操作的機制,包含以下步驟:創(chuàng)建計數(shù)器鍵、增加計數(shù)、減少計數(shù)、重置計數(shù)和獲取計數(shù)。Redis計數(shù)器的優(yōu)勢包括速度快、高并發(fā)、持久性和簡單易用。它可用于用戶訪問計數(shù)、實時指標(biāo)跟蹤、游戲分?jǐn)?shù)和排名以及訂單處理計數(shù)等場景。

如何理解C  中的ABI兼容性? 如何理解C 中的ABI兼容性? Apr 28, 2025 pm 10:12 PM

C 中的ABI兼容性是指不同編譯器或版本生成的二進制代碼能否在不重新編譯的情況下兼容。1.函數(shù)調(diào)用約定,2.名稱修飾,3.虛函數(shù)表布局,4.結(jié)構(gòu)體和類的布局是主要涉及的方面。

redis指令怎么用 redis指令怎么用 Apr 10, 2025 pm 08:45 PM

使用 Redis 指令需要以下步驟:打開 Redis 客戶端。輸入指令(動詞 鍵 值)。提供所需參數(shù)(因指令而異)。按 Enter 執(zhí)行指令。Redis 返回響應(yīng),指示操作結(jié)果(通常為 OK 或 -ERR)。

redis怎么使用鎖 redis怎么使用鎖 Apr 10, 2025 pm 08:39 PM

使用Redis進行鎖操作需要通過SETNX命令獲取鎖,然后使用EXPIRE命令設(shè)置過期時間。具體步驟為:(1) 使用SETNX命令嘗試設(shè)置一個鍵值對;(2) 使用EXPIRE命令為鎖設(shè)置過期時間;(3) 當(dāng)不再需要鎖時,使用DEL命令刪除該鎖。

notepad  怎么格式化json notepad 怎么格式化json Apr 16, 2025 pm 07:48 PM

使用 Notepad 中 JSON Viewer 插件可輕松格式化 JSON 文件:打開 JSON 文件。安裝并啟用 JSON Viewer 插件。轉(zhuǎn)到“插件”&gt;“JSON Viewer”&gt;“格式化 JSON”。自定義縮進、分行和排序設(shè)置。應(yīng)用格式化以提高可讀性和理解力,從而簡化 JSON 數(shù)據(jù)的處理和編輯。

HadiDB:Python 中的輕量級、可水平擴展的數(shù)據(jù)庫 HadiDB:Python 中的輕量級、可水平擴展的數(shù)據(jù)庫 Apr 08, 2025 pm 06:12 PM

HadiDB:輕量級、高水平可擴展的Python數(shù)據(jù)庫HadiDB(hadidb)是一個用Python編寫的輕量級數(shù)據(jù)庫,具備高度水平的可擴展性。安裝HadiDB使用pip安裝:pipinstallhadidb用戶管理創(chuàng)建用戶:createuser()方法創(chuàng)建一個新用戶。authentication()方法驗證用戶身份。fromhadidb.operationimportuseruser_obj=user("admin","admin")user_obj.

Redis內(nèi)存碎片如何處理? Redis內(nèi)存碎片如何處理? Apr 10, 2025 pm 02:24 PM

Redis內(nèi)存碎片是指分配的內(nèi)存中存在無法再分配的小塊空閑區(qū)域。應(yīng)對策略包括:重啟Redis:徹底清空內(nèi)存,但會中斷服務(wù)。優(yōu)化數(shù)據(jù)結(jié)構(gòu):使用更適合Redis的結(jié)構(gòu),減少內(nèi)存分配和釋放次數(shù)。調(diào)整配置參數(shù):使用策略淘汰最近最少使用的鍵值對。使用持久化機制:定期備份數(shù)據(jù),重啟Redis清理碎片。監(jiān)控內(nèi)存使用情況:及時發(fā)現(xiàn)問題并采取措施。

See all articles