회원가입 ID/PW 찾기

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

콘텐츠 수 149

이진검색트리

머신러닝, 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%를 돌려드립니다.
149 Allego & OrCAD orcad16.0 필요합니다 64비트용 무료 내마음의일식 2017-06-27 0 357
148 Allego & OrCAD orcad 16.0 설치 주소입니다. [2] 무료 Xorcad 2017-05-16 0 1330
147 Allego & OrCAD OrCAD PCB Editor 프로그램 질문드립니다. [1] 무료 kmgn0 2017-05-16 0 286
146 Allego & OrCAD OrCAD Capture "N-CH MosFET" 라이브러리 찾습니다. [3] 무료 내일의나 2017-03-07 0 226
145 Allego & OrCAD Negative Planes에 대해 질문 드립니다. [2] 무료 Astro 2017-02-14 0 163
144 Allego & OrCAD Orcad Netlist 추출 문의 [1] 무료 YEJUN 2017-02-10 0 200
143 Allego & OrCAD allegro pcb designer) 부품 배치 단계에서 bottom에 배치를 하고 싶은데 [3] 무료 호차미♡ 2017-01-20 0 271
142 Allego & OrCAD 마우스 드래그 표시 문의 드립니다. [1] 무료 미소비 2017-01-04 0 176
141 Allego & OrCAD ORCAD(Allegro) 16.6 추천 도서 부탁드립니다. [2] 무료 knightoffire 2017-01-03 0 316
140 Allego & OrCAD ORCAD PCB 설계 입문자 입니다. [1] 무료 호차미♡ 2016-11-18 0 506
139 Allego & OrCAD 질문)PCB 부품 Mirror(v16.5) [2] 무료 0808161114 2016-11-14 0 320
138 Allego & OrCAD 질문) Capture 부품 라이브러리 생성_Relay [2] 무료 0808161114 2016-10-19 0 479
137 Allego & OrCAD 시뮬레이션 하려고 하니 'cannot initialize profile'란 오류가 뜨네요.... [4] 무료 ddjde 2016-05-23 0 873
136 Allego & OrCAD win 10 호환 [9] 무료 Surium 2016-04-27 0 3318
135 Allego & OrCAD orcad 16.5 그것이 알고싶다. 무료 불멸자 2016-03-28 0 966
134 Allego & OrCAD 도와주세요~ outline 오류 [1] 무료 앙팡융 2016-03-15 0 210
133 Allego & OrCAD OrCAD16.6 설치방법 [18] 무료 빼빼로 2015-11-19 0 5141
132 Allego & OrCAD Cadence.OrCad.Allegro.SPB.16.2 가지고 계신분 무료 systec 2015-10-31 0 561
131 Allego & OrCAD 공부를시작하기전에 무료 qwe9606 2015-09-02 0 385
130 Allego & OrCAD 4층 설계하기 무료 보라색 2015-08-04 0 735
  • 인생은 선을 실행하기 위하여 만들어졌다.
    - 칸트
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.