激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - C語言 數據結構平衡二叉樹實例詳解

C語言 數據結構平衡二叉樹實例詳解

2021-05-18 16:23xlgen157387 C/C++

這篇文章主要介紹了C語言 數據結構平衡二叉樹實例詳解的相關資料,需要的朋友可以參考下

數據結構平衡二叉樹

參考代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
/*
  名稱:平衡二叉樹
  語言:數據結構C語言版 
  編譯環境:VC++ 6.0
  日期: 2014-3-26 
*/
#include <stdio.h>
#include <malloc.h>
#include <windows.h>
#define LH +1  // 左高 
#define EH 0  // 等高 
#define RH -1  // 右高 
#define N 5   // 數據元素個數 
 
typedef char KeyType; // 設關鍵字域為字符型 
 
typedef struct
{
  KeyType key;
  int order;
}ElemType; // 數據元素類型 
 
// 平衡二叉樹的類型 
typedef struct BSTNode
{
  ElemType data;
  // bf結點的平衡因子,只能夠取0,-1,1,它是左子樹的深度減去
  // 右子樹的深度得到的
  int bf; 
  struct BSTNode *lchild,*rchild; // 左、右孩子指針 
}BSTNode,*BSTree;
 
// 構造一個空的動態查找表DT
int InitDSTable(BSTree *DT) 
{
  *DT=NULL;
  return 1;
}
 
// 銷毀動態查找表DT 
void DestroyDSTable(BSTree *DT) 
{
  if(*DT) // 非空樹 
  {
    if((*DT)->lchild) // 有左孩子 
      DestroyDSTable(&(*DT)->lchild); // 銷毀左孩子子樹 
    if((*DT)->rchild) // 有右孩子 
      DestroyDSTable(&(*DT)->rchild); // 銷毀右孩子子樹 
    free(*DT); // 釋放根結點 
    *DT=NULL; // 空指針賦0 
  }
}
 
// 在根指針T所指二叉排序樹中遞歸地查找某關鍵字等于key的數據元素, 
// 若查找成功,則返回指向該數據元素結點的指針,否則返回空指針。
BSTree SearchBST(BSTree T,KeyType key)
{
  if((!T)|| (key == T->data.key))
    return T; // 查找結束 
  else if(key < T->data.key) // 在左子樹中繼續查找 
    return SearchBST(T->lchild,key);
  else
    return SearchBST(T->rchild,key); // 在右子樹中繼續查找 
}
 
// 對以*p為根的二叉排序樹作右旋處理,處理之后p指向新的樹根結點,即旋轉 
// 處理之前的左子樹的根結點。
void R_Rotate(BSTree *p)
{
  BSTree lc;
  lc=(*p)->lchild; // lc指向p的左子樹根結點 
  (*p)->lchild=lc->rchild; // lc的右子樹掛接為p的左子樹 
  lc->rchild=*p;
  *p=lc; // p指向新的根結點 
}
 
// 對以*p為根的二叉排序樹作左旋處理,處理之后p指向新的樹根結點,即旋轉 
// 處理之前的右子樹的根結點。
void L_Rotate(BSTree *p)
{
  BSTree rc;
  rc=(*p)->rchild; // rc指向p的右子樹根結點 
  (*p)->rchild=rc->lchild; // rc的左子樹掛接為p的右子樹 
  rc->lchild=*p;
  *p=rc; // p指向新的根結點 
}
 
// 對以指針T所指結點為根的二叉樹作左平衡旋轉處理,本算法結束時, 
// 指針T指向新的根結點。
void LeftBalance(BSTree *T)
{  
  BSTree lc,rd;
  lc=(*T)->lchild; // lc指向*T的左子樹根結點 
  switch(lc->bf)
  { // 檢查*T的左子樹的平衡度,并作相應平衡處理 
  case LH: // 新結點插入在*T的左孩子的左子樹上,要作單右旋處理 
    (*T)->bf=lc->bf=EH;
    R_Rotate(T);
    break;
  case RH: // 新結點插入在*T的左孩子的右子樹上,要作雙旋處理 
    rd=lc->rchild; // rd指向*T的左孩子的右子樹根 
    switch(rd->bf)
    { // 修改*T及其左孩子的平衡因子 
    case LH:
      (*T)->bf=RH;
      lc->bf=EH;
      break;
    case EH: 
      (*T)->bf=lc->bf=EH;
      break;
    case RH:
      (*T)->bf=EH;
      lc->bf=LH;
    }
    rd->bf=EH;
    L_Rotate(&(*T)->lchild); // 對*T的左子樹作左旋平衡處理 
    R_Rotate(T); // 對*T作右旋平衡處理 
  }
}
 
// 對以指針T所指結點為根的二叉樹作右平衡旋轉處理,本算法結束時, 
// 指針T指向新的根結點
void RightBalance(BSTree *T)
{
  BSTree rc,rd;
  rc=(*T)->rchild; // rc指向*T的右子樹根結點 
  switch(rc->bf)
  { // 檢查*T的右子樹的平衡度,并作相應平衡處理 
  case RH: // 新結點插入在*T的右孩子的右子樹上,要作單左旋處理 
    (*T)->bf=rc->bf=EH;
    L_Rotate(T);
    break;
  case LH: // 新結點插入在*T的右孩子的左子樹上,要作雙旋處理 
    rd=rc->lchild; // rd指向*T的右孩子的左子樹根 
    switch(rd->bf)
    { // 修改*T及其右孩子的平衡因子 
    case RH: (*T)->bf=LH;
      rc->bf=EH;
      break;
    case EH: (*T)->bf=rc->bf=EH;
      break;
    case LH: (*T)->bf=EH;
      rc->bf=RH;
    }
    rd->bf=EH;
    R_Rotate(&(*T)->rchild); // 對*T的右子樹作右旋平衡處理 
    L_Rotate(T); // 對*T作左旋平衡處理 
  }
}
 
// 若在平衡的二叉排序樹T中不存在和e有相同關鍵字的結點,則插入一個 
// 數據元素為e的新結點,并返回1,否則返回0。若因插入而使二叉排序樹 
// 失去平衡,則作平衡旋轉處理,布爾變量taller反映T長高與否。 
int InsertAVL(BSTree *T,ElemType e,int *taller)
{
  if(!*T)
  { // 插入新結點,樹“長高”,置taller為1 
    *T=(BSTree)malloc(sizeof(BSTNode));
    (*T)->data=e;
    (*T)->lchild=(*T)->rchild=NULL;
    (*T)->bf=EH;
    *taller=1;
  }
  else
  {
    if(e.key == (*T)->data.key)
    { // 樹中已存在和e有相同關鍵字的結點則不再插入 
      *taller=0;
      return 0;
    }
    if(e.key < (*T)->data.key)
    { // 應繼續在*T的左子樹中進行搜索 
      if(!InsertAVL(&(*T)->lchild,e,taller)) // 未插入 
        return 0;
      if(*taller)
        // 已插入到*T的左子樹中且左子樹“長高” 
        switch((*T)->bf) // 檢查*T的平衡度 
        {
        case LH:
          // 原本左子樹比右子樹高,需要作左平衡處理 
          LeftBalance(T);
          *taller=0; //標志沒長高
          break;
        case EH:
          // 原本左、右子樹等高,現因左子樹增高而使樹增高 
          (*T)->bf=LH;
          *taller=1; //標志長高
          break;
        case RH:
          // 原本右子樹比左子樹高,現左、右子樹等高
          (*T)->bf=EH; 
          *taller=0; //標志沒長高
      }
    }
    else
    {
      // 應繼續在*T的右子樹中進行搜索 
      if(!InsertAVL(&(*T)->rchild,e,taller)) // 未插入 
        return 0;
      if(*taller) // 已插入到T的右子樹且右子樹“長高” 
        switch((*T)->bf) // 檢查T的平衡度 
      {
      case LH: 
        (*T)->bf=EH; // 原本左子樹比右子樹高,現左、右子樹等高 
        *taller=0;
        break;
      case EH: // 原本左、右子樹等高,現因右子樹增高而使樹增高 
        (*T)->bf=RH;
        *taller=1;
        break;
      case RH: // 原本右子樹比左子樹高,需要作右平衡處理 
        RightBalance(T);
        *taller=0;
      }
    }
  }
  return 1;
}
 
// 按關鍵字的順序對DT的每個結點調用函數Visit()一次
void TraverseDSTable(BSTree DT,void(*Visit)(ElemType))
  if(DT)
  {
    TraverseDSTable(DT->lchild,Visit); // 先中序遍歷左子樹 
    Visit(DT->data); // 再訪問根結點 
    TraverseDSTable(DT->rchild,Visit); // 最后中序遍歷右子樹 
  }
}
 
 
void print(ElemType c)
{
  printf("(%d,%d)",c.key,c.order);
}
 
int main()
{
  BSTree dt,p;
  int k;
  int i;
  KeyType j;
  ElemType r[N]={
    {13,1},{24,2},{37,3},{90,4},{53,5}
  }; // (以教科書P234圖9.12為例) 
   
  InitDSTable(&dt);  // 初始化空樹 
  for(i=0;i<N;i++)
    InsertAVL(&dt,r[i],&k); // 建平衡二叉樹 
  TraverseDSTable(dt,print); // 按關鍵字順序遍歷二叉樹 
  printf("\n請輸入待查找的關鍵字: ");
  scanf("%d",&j);
  p=SearchBST(dt,j); // 查找給定關鍵字的記錄 
  if(p)
    print(p->data);
  else
    printf("表中不存在此值");
  printf("\n");
  DestroyDSTable(&dt);
   
  system("pause");
  return 0;
}
/*
輸出效果:
 
(13,1)(24,2)(37,3)(53,5)(90,4)
請輸入待查找的關鍵字: 53
(53,5)
請按任意鍵繼續. . . 
 
*/

運行結果如下:

C語言 數據結構平衡二叉樹實例詳解

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

原文鏈接:http://blog.csdn.net/xlgen157387/article/details/22169107

延伸 · 閱讀

精彩推薦
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
主站蜘蛛池模板: 黄在线观看 | 欧美aaaaa一级毛片在线 | 激情视频在线播放 | 羞羞网站在线看 | 色域tv | 久久国产精品久久久久 | 成人午夜在线观看视频 | 国产91久久久 | 亚洲综合一区在线观看 | 一级毛片在线观看免费 | 中文字幕亚洲情99在线 | 九九午夜视频 | 欧美视屏一区二区 | 耽美男男肉文 | 久久91精品 | 国产成人免费精品 | 黄在线免费看 | 日韩精品一区二区三区中文 | 成人免费一区二区三区视频网站 | 午夜小影院| 神马久久精品综合 | 99麻豆久久久国产精品免费 | 毛片免费试看 | 久久久资源网 | 成年人观看免费视频 | 91av在线免费观看 | 国产精品av久久久久久网址 | 免费看日韩片 | 精精国产xxxx视频在线野外 | 国产毛片在线看 | 欧美高清视频一区 | 日韩在线欧美在线 | 91精品国产九九九久久久亚洲 | 久久国产夫妻视频 | 久久久成人精品视频 | 《97色伦在色在线播放》 | 一区二区三区在线观看国产 | 萌白酱福利视频在线网站 | 成人在线视频精品 | 欧美第1页 | 日本特级a一片免费观看 |