회원가입 ID/PW 찾기

1) 지식 창고는 본인이 작성한 콘텐츠(팁/노하우/리소스/강좌 등)을 무료 혹은 가상화폐인 납포인트를 통해 공유하는 공간입니다.
2) 본인이 작성한 콘텐츠에 대해서만 지식 창고에 등록할 수 있으며, 저작권에 위배되는 콘텐츠는 사전경고 없이 삭제될 수 있습니다.
3) 콘텐츠 구매 및 첨부파일 다운로드는 회원그룹 '연구원' 이상 가능하오니, 경험치를 쌓아 진급한 후에 이용 부탁드립니다.
4) 무료 콘텐츠의 본문은 구매절차 없이 즉시 이용할 수 있으며, 판매 납포인트가 있는 콘텐츠는 구매 후 이용할 수 있습니다.
5) 콘텐츠 판매에 따른 납포인트 수익은 지정한 비율(50%)에 따라 판매자에게 지급하며, 납포인트 수익을 통해 진급을 빨리할 수 있습니다.
6) 구매 후 평가를 하면 구매 납포인트의 20%를 돌려 드립니다.

콘텐츠 수 1,041

이진검색트리

머신러닝, AI & 알고리즘 구매수 0 2007.09.30 03:49:34
판매자 아크마 판매 납포인트 무료 평점 0점 / 총 0명 참여

template <class T>
struct node{
  int key;
  T data;
  node* left;
  node* right;
  node(int k, T x): key(k), data(x), left(0), right(0) {}
};

template <class T>
class binarySearchTree{
public:
  binarySearchTree(): root(0) {
  //ARG:
  //DESC: root is initialized with 0.
  }
  ~binarySearchTree(){
  //ARG:
  //DESC: memory allocated for search tree is freed.
    _delete(root);
  }
  T* search(int k) const {
  //ARG:
  //DESC: return value is data item of a node with key == k,
  //      if such a node exists; otherwise it is 0.
    return search(root, k);
  }
  void insert(int k, T d){
   //ARG: binary search tree rooted at root (can be empty).
   //DESC: binary search tree contains node with key k
   //      and data item d.
    insert(root, k, d);
  }
  void insertAsRoot(int k, T d){
  //ARG: binary search tree rooted at root (can be empty).
  //DESC: binary search rooted at root. The node at the root
  //      has key k and data item d.
    insertAsRoot(root, k, d);
  }
  void remove(int k) {
  //ARG: binary rooted at root.
  //DESC: binary tree rooted at root from  which a node
  //      with key k has been removed.
    remove(root, k);
  }
  void inOrderWalk() const {
  //ARG: binary search tree rooted at root.
  //DESC: all keys stored in the tree are printed in
  //      increasing order on stdout.
    inOrderWalk(root);
  }
  int minKey() const {
  //ARG: non-empty binary search tree rooted at root.
  //DESC: the minimum key stored in the tree is returned.
    return minKey(root);
  }
  int maxKey() const {
  //ARG: non-empty binary search tree rooted at root.
  //DESC: the maximum key stored in the tree is returned.
    return maxKey(root);
  }
private:
  node<T>* root;
  void _delete(node<T>* p);
  T* search(node<T>* p, int k) const;
  void insert(node<T>* &p, int k, T d);
  void rotateRight(node<T>* p);
  void rotateLeft(node<T>* p);
  void insertAsRoot(node<T>* &p, int k, T d);
  void remove(node<T>* &p, int k);
  void inOrderWalk(node<T>* p) const;
  int minKey(node<T>* p) const;
  int maxKey(node<T>* p) const;
};

template <class T>
void binarySearchTree<T>::_delete(node<T>* p){
//ARG:
//DESC: memory allocated for tree rooted at p is freed.
  if(p != 0){
    _delete(p->left);
    _delete(p->right);
    delete p; 
  }
}

template <class T>
T* binarySearchTree<T>::search(node<T>* p, int k) const{
//ARG:
//DESC: return value is data item of a node with key == k,
//      if such a node exists; otherwise it is 0.
  if(p == 0) return 0;
  int kk = p->key;
  if(kk == k) return &(p->data);
  if(kk < k) return search(p->left, k);
  else return search(p->right, k);
}

template <class T>
void binarySearchTree<T>::insert(node<T>* &p, int k, T d){
//ARG: binary search tree rooted at p (can be empty).
//DESC: binary search tree rooted at p that contains node
//      with key k and data item d.
  if(p == 0)
    p = new node<T>(k ,d);
  else if(k < p->key) //convention, could also use <=
    insert(p->left, k, d);
  else
    insert(p->right, k, d);
}

template <class T>
void binarySearchTree<T>::rotateRight(node<T>* p){
//ARG: (1) p->left != 0
//     (2) binary search tree rooted at p.
//DESC: binary search tree rooted at p->left.
  node<T>* q = p->left;
  p->left = q->right;
  q->right = p;
  p = q;
}

template <class T>
void binarySearchTree<T>::rotateLeft(node<T>* p){
//ARG: (1) p->right != 0
//     (2) binary search tree rooted at p.
//DESC: binary search tree rooted at p->right.
  node<T>* q = p->right;
  p->right = q->left;
  q->left = p;
  p = q;
}

template <class T>
void binarySearchTree<T>::insertAsRoot(node<T>* &p, int k, T d){
//ARG: binary search tree rooted at p (can be empty).
//DESC: binary search rooted at p. The node pointed to
//      by p has key k and data item d.
  if(p == 0)
    p = new node<T>(k ,d);
  else if(k < p->key){ //convention; could also use <=
    insertAsRoot(p->left, k, d);
    rotateRight(p);
  } else{
    insert(p->right, k, d);
    rotateLeft(p);
  }
}

template <class T>
void binarySearchTree<T>::remove(node<T>* &p, int k){
//ARG: binary rooted at p.
//DESC: binary tree rooted at p from  which a node
//      with key k has been removed if there was one.
  if(p == 0) return;
  int kk = p->key;
  if(k < kk){
    remove(p->left, k);
    return;
  }
  if(k > kk){
    remove(p->right, k);
    return;
  }
  node<T>* q = p;
  node<T>* r = p->right;
  if(r == 0)
    p = p->left;
  else{
    while(r->left != 0)
      rotateRight(r);
    r->left = p->left;
    p = r;
  }
  delete q;
}

template <class T>
void binarySearchTree<T>::inOrderWalk(node<T>* p) const {
//ARG: binary search tree rooted at p.
//DESC: all keys stored in the tree rooted at p
//     are printed in increasing order on stdout.
  if(p != 0){
    inOrderWalk(p->left);
    std::cout << "[" << p->key << "]";
    inOrderWalk(p->right);
  }
}

template <class T>
int binarySearchTree<T>::minKey(node<T>* p) const {
//ARG: non-empty binary search tree rooted at p.
//DESC: the minimum key stored in the tree rooted
//      at p is returned.
  while(p->left != 0)
    p = p->left;
  return p->key;
}

template <class T>
int binarySearchTree<T>::maxKey(node<T>* p) const {
//ARG: non-empty binary search tree rooted at p.
//DESC: the maximum key stored in the tree rooted
//      at p is returned.
  while(p->right != 0)
    p = p->right;
  return p->key;
}

 

 

 

 


 

모르는 것이 무엇인지 스스로 정리하고 질문하는 습관을 가집시다.
무성의/광범위하거나 직접 해보지 않고 올리는 질문은 서로를 피곤하게 합니다.
질문쪽지는 사절이오니 게시판에 글을 남겨주세요. 그래야 다같이 공유할 수 있으니까요.


profile
YJ 2008.03.10 15:52
C++ 맞죠? ^^;.
profile
Sadcy 2008.08.11 15:15

템플릿을 사용하셨네요-^^
잘 사용하겠습니다:)

profile
원조달구지 2009.11.13 14:58
머리 아프네요..어렵습니다.
profile
페라리블루 2010.04.08 18:47
아~ 머리아퍼.. ^^'
profile
dosososo 2013.11.24 14:22
감사합니다 ㅎ
profile
시나브로69 2017.06.24 15:10
좋은 자료 감사합니다.
search
List of Articles
번호 분류 제목 평점 포인트 판매자 등록일 구매수 조회 수
공지 공공의 목적으로 공유하고자 하는 소프트웨어는 '소프트웨어 자료실'에 업로드를 요청드립니다.
공지 구매후 평점 댓글을 남겨주시면 구매포인트의 20%를 돌려드립니다.
221 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CToolBar(c) " [2] 무료 뺘쑝 2007-10-03 0 1382
220 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CScrollView " [3] 무료 뺘쑝 2007-10-03 0 1411
219 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CRecordView " [2] 무료 뺘쑝 2007-10-03 0 1147
218 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CPropertySheet(c) " [2] 무료 뺘쑝 2007-10-03 0 1450
217 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CMenu " [3] 무료 뺘쑝 2007-10-03 0 1287
216 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CFrameWnd " [3] 무료 뺘쑝 2007-10-03 0 1137
215 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CEditView " [2] 무료 뺘쑝 2007-10-03 0 1173
214 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CDialogBar " [2] 무료 뺘쑝 2007-10-03 0 1296
213 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CDaoRecordView " [2] 무료 뺘쑝 2007-10-03 0 1145
212 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CControlBar " [3] 무료 뺘쑝 2007-10-03 0 1437
211 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CTreeView " [2] 무료 뺘쑝 2007-10-03 0 1387
210 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CSocket " [3] 무료 뺘쑝 2007-10-03 0 1413
209 펌웨어 & 코딩언어 [ 영문판 번역 ] Visual C++ " CRichEditView " [3] 무료 뺘쑝 2007-10-03 0 1500
208 마이크로프로세서 코드 비전 사용방법 입니다 [14] 무료 뺘쑝 2007-10-03 0 5150
207 펌웨어 & 코딩언어 The Art of Assembly Language [4] 무료 아크마 2007-09-30 0 2347
206 머신러닝, AI & 알고리즘 정렬여부 판단 알고리즘 소스 [3] 무료 아크마 2007-09-30 0 1940
205 머신러닝, AI & 알고리즘 삽입정렬 알고리즘 소스 [6] 무료 아크마 2007-09-30 0 3229
204 머신러닝, AI & 알고리즘 무작위(랜덤) 선택 알고리즘 소스 [6] 무료 아크마 2007-09-30 0 3298
203 머신러닝, AI & 알고리즘 힙정렬 소스 [2] 무료 아크마 2007-09-30 0 4051
» 머신러닝, AI & 알고리즘 이진검색트리 [6] 무료 아크마 2007-09-30 0 2721
  • 모든 죄악의 기본은 조바심과 게으름이다.
    - 카프카
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.