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

首頁 後端開發(fā) C++ C語言數(shù)據(jù)結(jié)構(gòu):樹和圖的數(shù)據(jù)表示與操作

C語言數(shù)據(jù)結(jié)構(gòu):樹和圖的數(shù)據(jù)表示與操作

Apr 04, 2025 am 11:18 AM
c語言

C語言數(shù)據(jù)結(jié)構(gòu):樹和圖的數(shù)據(jù)表示與操作

C語言數(shù)據(jù)結(jié)構(gòu):樹和圖的數(shù)據(jù)表示與操作

  • 是一個層次結(jié)構(gòu)的數(shù)據(jù)結(jié)構(gòu)
  • 由節(jié)點組成,每個節(jié)點包含一個數(shù)據(jù)元素和指向其子節(jié)點的指針
  • 二叉樹是一種特殊類型的樹,其中每個節(jié)點最多有兩個子節(jié)點

數(shù)據(jù)表示

struct TreeNode {
    int data;
    struct TreeNode *left;
    struct TreeNode *right;
};

操作

  • 創(chuàng)建樹
  • 遍歷樹(先序、中序、後序)
  • 搜索樹
  • 插入節(jié)點
  • 刪除節(jié)點

  • 是一個集合的數(shù)據(jù)結(jié)構(gòu),其中的元素是頂點,它們通過邊連接在一起
  • 邊可以是帶權(quán)或無權(quán)的

數(shù)據(jù)表示

鄰接矩陣:

 int adjMatrix[V][V];

鄰接表:

 struct AdjListNode {
    int dest;
    struct AdjListNode *next;
};

struct AdjList {
    struct AdjListNode *head;
};

struct Graph {
    int V;
    struct AdjList *array;
};

操作

  • 創(chuàng)建圖
  • 添加邊
  • 遍歷圖
  • 查找最短路徑

實戰(zhàn)案例:二叉查找樹

二叉查找樹是一種二叉樹,其數(shù)據(jù)元素在樹中按順序存儲。這使得搜索、插入和刪除操作非常高效。

 // 創(chuàng)建二叉查找樹struct TreeNode *createBST(int data) {
    struct TreeNode *root = malloc(sizeof(struct TreeNode));
    root->data = data;
    root->left = root->right = NULL;
    return root;
}

// 在二叉查找樹中搜索元素int searchBST(struct TreeNode *root, int data) {
    if (!root) {
        return 0;
    } else if (root->data == data) {
        return 1;
    } else if (data < root->data) {
        return searchBST(root->left, data);
    } else {
        return searchBST(root->right, data);
    }
}

// 在二叉查找樹中插入元素struct TreeNode *insertBST(struct TreeNode *root, int data) {
    if (!root) {
        return createBST(data);
    } else if (data < root->data) {
        root->left = insertBST(root->left, data);
    } else if (data > root->data) {
        root->right = insertBST(root->right, data);
    }
    return root;
}

// 在二叉查找樹中刪除元素struct TreeNode *deleteBST(struct TreeNode *root, int data) {
    if (!root) {
        return NULL;
    } else if (data < root->data) {
        root->left = deleteBST(root->left, data);
    } else if (data > root->data) {
        root->right = deleteBST(root->right, data);
    } else {
        // 如果節(jié)點有兩個子節(jié)點,則找到前驅(qū)(左子樹中最右節(jié)點)或後繼(右子樹中最左節(jié)點)
        if (root->left && root->right) {
            int successor = root->right->data;
            root->data = successor;
            root->right = deleteBST(root->right, successor);
        } else if (root->left) {
            struct TreeNode *temp = root->left;
            free(root);
            return temp;
        } else if (root->right) {
            struct TreeNode *temp = root->right;
            free(root);
            return temp;
        } else {
            free(root);
            return NULL;
        }
    }
    return root;
}

以上是C語言數(shù)據(jù)結(jié)構(gòu):樹和圖的數(shù)據(jù)表示與操作的詳細內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔相應(yīng)的法律責任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)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)

C語言數(shù)據(jù)結(jié)構(gòu):樹和圖的數(shù)據(jù)表示與操作 C語言數(shù)據(jù)結(jié)構(gòu):樹和圖的數(shù)據(jù)表示與操作 Apr 04, 2025 am 11:18 AM

C語言數(shù)據(jù)結(jié)構(gòu):樹和圖的數(shù)據(jù)表示與操作樹是一個層次結(jié)構(gòu)的數(shù)據(jù)結(jié)構(gòu)由節(jié)點組成,每個節(jié)點包含一個數(shù)據(jù)元素和指向其子節(jié)點的指針二叉樹是一種特殊類型的樹,其中每個節(jié)點最多有兩個子節(jié)點數(shù)據(jù)表示structTreeNode{intdata;structTreeNode*left;structTreeNode*right;};操作創(chuàng)建樹遍歷樹(先序、中序、後序)搜索樹插入節(jié)點刪除節(jié)點圖是一個集合的數(shù)據(jù)結(jié)構(gòu),其中的元素是頂點,它們通過邊連接在一起邊可以是帶權(quán)或無權(quán)的數(shù)據(jù)表示鄰

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){

C語言文件操作難題的幕後真相 C語言文件操作難題的幕後真相 Apr 04, 2025 am 11:24 AM

文件操作難題的真相:文件打開失?。簷?quán)限不足、路徑錯誤、文件被佔用。數(shù)據(jù)寫入失?。壕徯n區(qū)已滿、文件不可寫、磁盤空間不足。其他常見問題:文件遍歷緩慢、文本文件編碼不正確、二進製文件讀取錯誤。

CS-第 3 週 CS-第 3 週 Apr 04, 2025 am 06:06 AM

算法是解決問題的指令集,其執(zhí)行速度和內(nèi)存佔用各不相同。編程中,許多算法都基於數(shù)據(jù)搜索和排序。本文將介紹幾種數(shù)據(jù)檢索和排序算法。線性搜索假設(shè)有一個數(shù)組[20,500,10,5,100,1,50],需要查找數(shù)字50。線性搜索算法會逐個檢查數(shù)組中的每個元素,直到找到目標值或遍歷完整個數(shù)組。算法流程圖如下:線性搜索的偽代碼如下:檢查每個元素:如果找到目標值:返回true返回falseC語言實現(xiàn):#include#includeintmain(void){i

C語言多線程編程:新手指南與疑難解答 C語言多線程編程:新手指南與疑難解答 Apr 04, 2025 am 10:15 AM

C語言多線程編程指南:創(chuàng)建線程:使用pthread_create()函數(shù),指定線程ID、屬性和線程函數(shù)。線程同步:通過互斥鎖、信號量和條件變量防止數(shù)據(jù)競爭。實戰(zhàn)案例:使用多線程計算斐波那契數(shù),將任務(wù)分配給多個線程並同步結(jié)果。疑難解答:解決程序崩潰、線程停止響應(yīng)和性能瓶頸等問題。

c語言如何輸出倒數(shù) c語言如何輸出倒數(shù) Apr 04, 2025 am 08:54 AM

如何在 C 語言中輸出倒數(shù)?回答:使用循環(huán)語句。步驟:1. 定義變量 n 存儲要輸出的倒數(shù)數(shù)字;2. 使用 while 循環(huán)持續(xù)打印 n 直到 n 小於 1;3. 在循環(huán)體內(nèi),打印出 n 的值;4. 在循環(huán)末尾,將 n 減去 1 以輸出下一個更小的倒數(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)體和類的佈局是主要涉及的方面。

c語言函數(shù)的定義調(diào)用聲明格式怎麼搞 c語言函數(shù)的定義調(diào)用聲明格式怎麼搞 Apr 04, 2025 am 06:03 AM

C語言函數(shù)包含定義、調(diào)用和聲明。函數(shù)定義指定函數(shù)名、參數(shù)和返回類型,函數(shù)體實現(xiàn)功能;函數(shù)調(diào)用執(zhí)行函數(shù)並提供參數(shù);函數(shù)聲明告知編譯器函數(shù)類型。值傳遞用於參數(shù)傳遞,注意返回類型,保持一致的代碼風格,並在函數(shù)中處理錯誤。掌握這些知識有助於編寫優(yōu)雅、健壯的C代碼。

See all articles