C#二叉搜索树插入算法实例分析

本文实例讲述了C#二叉搜索树插入算法。分享给大家供大家参考。具体实现方法如下:

public class BinaryTreeNode
{
 public BinaryTreeNode Left { get; set; }
 public BinaryTreeNode Right { get; set; }
 public int Data { get; set; }
 public BinaryTreeNode(int data)
 {
  this.Data = data;
 }
}
public void InsertIntoBST(BinaryTreeNode root, int data)
{
  BinaryTreeNode _newNode = new BinaryTreeNode(data);
  BinaryTreeNode _current = root;
  BinaryTreeNode _previous = _current;
  while (_current != null)
  {
   if (data < _current.Data)
   {
    _previous = _current;
    _current = _current.Left;
   }
   else if (data > _current.Data)
   {
    _previous = _current;
    _current = _current.Right;
   }
  }
  if (data < _previous.Data)
   _previous.Left = _newNode;
  else
   _previous.Right = _newNode;
}

希望本文所述对大家的C#程序设计有所帮助。

声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。