C#實現(xiàn)二叉排序樹代碼實例
更新時間:2018年10月25日 12:01:39 作者:Czhenya
今天小編就為大家分享一篇關于C#實現(xiàn)二叉排序樹代碼實例,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
二叉排序樹,又稱為二叉查找樹。它或者是一顆空樹,或者是具有下列性質的二叉樹:
- 若它的左子樹不為空。則左子樹上所有的結點的值均小于跟的結點值
- 若它的右子樹部位空,則右子樹的所有結點值均大于它的根結點的值
- 它的左右子樹也分別是二叉排序樹
1,排序方便
2,查找方便
3,便于插入和刪除

C#鏈式存儲二叉排序樹,實現(xiàn)簡單的排序,以及查找,具體代碼如下:
namespace _2_1_3二叉排序樹
{
/// <summary>
/// 結點類
/// </summary>
class BSNode
{
//結點
public BSNode LeftChild { get; set; }
public BSNode RightChild { get; set; }
public BSNode Parent { get; set; }
public int Data { get; set; }
// 構造方法
public BSNode(){}
public BSNode(int item)
{
this.Data = item;
}
}
}
using System;
namespace _2_1_3二叉排序樹
{
/// <summary>
/// 二叉排序樹
/// </summary>
class BSTree
{
BSNode root = null;
/// <summary>
/// 添加數(shù)據(jù)
/// </summary>
public void Add(int item)
{
//創(chuàng)建新結點
BSNode newNode = new BSNode(item);
if (root == null) //若為空,則創(chuàng)建為根結點
{
root = newNode;
}
else
{
BSNode temp = root;
while (true)
{
if (item >= temp.Data) //放在temp結點的右邊
{
if (temp.RightChild == null)
{
temp.RightChild = newNode;
newNode.Parent = temp;
break;
}
else
{
temp = temp.RightChild;
}
}
else //放在temp結點的左邊
{
if (temp.LeftChild == null)
{
temp.LeftChild = newNode;
newNode.Parent = temp;
break;
}
else
{
temp = temp.LeftChild;
}
}
}
}
}
/// <summary>
/// 中序遍歷二叉樹
/// </summary>
public void MiddleBianli()
{
MiddleBianli(root);
}
//遞歸方式中序遍歷樹
private void MiddleBianli(BSNode node)
{
if (node == null) return;
MiddleBianli(node.LeftChild);
Console.Write(node.Data + " ");
MiddleBianli(node.RightChild);
}
/// <summary>
///查找方法-1
/// </summary>
public bool Find1(int item)
{
return Find(item, root);
}
private bool Find(int item, BSNode node)
{
if (node == null) { return false; }
if (node.Data == item)
{
return true;
}
else
{
//利用二叉排序樹的便利
if (item > node.Data)
{
return Find(item, node.RightChild);
}
else
{
return Find(item, node.LeftChild);
}
}
}
/// <summary>
/// 查找方法-2
/// </summary>
/// <param name="item"></param>
/// <returns></returns>
public bool Find2(int item)
{
BSNode temp = root;
while (true)
{
if (temp == null) return false;
if (temp.Data == item) return true;
if (item > temp.Data)
{
temp = temp.RightChild;
}
else
{
temp = temp.LeftChild;
}
}
}
public bool Delete(int item)
{
BSNode temp = root;
while (true)
{
if (temp == null) return false;
if (temp.Data == item)
{
Delete(temp);
return true;
}
if (item > temp.Data)
{
temp = temp.RightChild;
}
else
{
temp = temp.LeftChild;
}
}
}
public void Delete(BSNode node)
{
//葉子結點,即無子樹情況
if (node.LeftChild == null && node.RightChild == null)
{
if (node.Parent == null)
{
root = null;
}
else if (node.Parent.LeftChild == node)
{
node.Parent.LeftChild = null;
}
else if (node.Parent.RightChild == node)
{
node.Parent.RightChild = null;
}
return;
}
//只有右子樹的情況
if (node.LeftChild == null && node.RightChild != null)
{
node.Data = node.RightChild.Data;
node.RightChild = null;
return;
}
//只有左子樹的情況
if (node.LeftChild != null && node.RightChild == null)
{
node.Data = node.LeftChild.Data;
node.LeftChild = null;
return;
}
//刪除的結點有左,右子樹
BSNode temp = node.RightChild;
while (true)
{
if (temp.LeftChild != null)
{
temp = temp.LeftChild;
}
else
{
break;
}
}
node.Data = temp.Data;
Delete(temp);
}
}
}
using System;
namespace _2_1_3二叉排序樹
{
/// <summary>
/// 測試類
/// </summary>
class Program
{
static void Main(string[] args)
{
BSTree tree = new BSTree();
int[] data = {62,58,28,47,73,99,35,51,93,37 };
foreach (int item in data)
{
tree.Add(item);
}
Console.Write("中序遍歷的結果:");
tree.MiddleBianli();
Console.WriteLine();
Console.WriteLine("Find-1方法查找62是否存在:" + tree.Find1(62));
Console.WriteLine("Find-2方法查找62是否存在:" + tree.Find2(62));
Console.WriteLine("Find-1方法查找63是否存在:" + tree.Find1(63));
Console.WriteLine("Find-2方法查找63是否存在:" + tree.Find2(63));
Console.WriteLine("刪除根結點后的結果:");
tree.Delete(62);
tree.MiddleBianli();
Console.ReadKey();
}
}
}

總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內(nèi)容請查看下面相關鏈接
相關文章
WPF自定義控件實現(xiàn)ItemsControl魚眼效果
這篇文章主要為大家詳細介紹了WPF如何通過自定義控件實現(xiàn)ItemsControl魚眼效果,文中的示例代碼講解詳細,需要的可以參考一下2024-01-01
使用GPS經(jīng)緯度定位附近地點(某一點范圍內(nèi)查詢)
目前的工作是需要手機查找附近N米以內(nèi)的商戶,致想法是已知一個中心點,一個半徑,求圓包含于圓拋物線里所有的點,經(jīng)緯度是一個點,半徑是一個距離,不能直接加減,下面提供C#的解決方法2013-12-12

