모바일 오유 바로가기
http://m.todayhumor.co.kr
분류 게시판
베스트
  • 베스트오브베스트
  • 베스트
  • 오늘의베스트
  • 유머
  • 유머자료
  • 유머글
  • 이야기
  • 자유
  • 고민
  • 연애
  • 결혼생활
  • 좋은글
  • 자랑
  • 공포
  • 멘붕
  • 사이다
  • 군대
  • 밀리터리
  • 미스터리
  • 술한잔
  • 오늘있잖아요
  • 투표인증
  • 새해
  • 이슈
  • 시사
  • 시사아카이브
  • 사회면
  • 사건사고
  • 생활
  • 패션
  • 패션착샷
  • 아동패션착샷
  • 뷰티
  • 인테리어
  • DIY
  • 요리
  • 커피&차
  • 육아
  • 법률
  • 동물
  • 지식
  • 취업정보
  • 식물
  • 다이어트
  • 의료
  • 영어
  • 맛집
  • 추천사이트
  • 해외직구
  • 취미
  • 사진
  • 사진강좌
  • 카메라
  • 만화
  • 애니메이션
  • 포니
  • 자전거
  • 자동차
  • 여행
  • 바이크
  • 민물낚시
  • 바다낚시
  • 장난감
  • 그림판
  • 학술
  • 경제
  • 역사
  • 예술
  • 과학
  • 철학
  • 심리학
  • 방송연예
  • 연예
  • 음악
  • 음악찾기
  • 악기
  • 음향기기
  • 영화
  • 다큐멘터리
  • 국내드라마
  • 해외드라마
  • 예능
  • 팟케스트
  • 방송프로그램
  • 무한도전
  • 더지니어스
  • 개그콘서트
  • 런닝맨
  • 나가수
  • 디지털
  • 컴퓨터
  • 프로그래머
  • IT
  • 안티바이러스
  • 애플
  • 안드로이드
  • 스마트폰
  • 윈도우폰
  • 심비안
  • 스포츠
  • 스포츠
  • 축구
  • 야구
  • 농구
  • 바둑
  • 야구팀
  • 삼성
  • 두산
  • NC
  • 넥센
  • 한화
  • SK
  • 기아
  • 롯데
  • LG
  • KT
  • 메이저리그
  • 일본프로야구리그
  • 게임1
  • 플래시게임
  • 게임토론방
  • 엑스박스
  • 플레이스테이션
  • 닌텐도
  • 모바일게임
  • 게임2
  • 던전앤파이터
  • 마비노기
  • 마비노기영웅전
  • 하스스톤
  • 히어로즈오브더스톰
  • gta5
  • 디아블로
  • 디아블로2
  • 피파온라인2
  • 피파온라인3
  • 워크래프트
  • 월드오브워크래프트
  • 밀리언아서
  • 월드오브탱크
  • 블레이드앤소울
  • 검은사막
  • 스타크래프트
  • 스타크래프트2
  • 베틀필드3
  • 마인크래프트
  • 데이즈
  • 문명
  • 서든어택
  • 테라
  • 아이온
  • 심시티5
  • 프리스타일풋볼
  • 스페셜포스
  • 사이퍼즈
  • 도타2
  • 메이플스토리1
  • 메이플스토리2
  • 오버워치
  • 오버워치그룹모집
  • 포켓몬고
  • 파이널판타지14
  • 배틀그라운드
  • 기타
  • 종교
  • 단어장
  • 자료창고
  • 운영
  • 공지사항
  • 오유운영
  • 게시판신청
  • 보류
  • 임시게시판
  • 메르스
  • 세월호
  • 원전사고
  • 2016리오올림픽
  • 2018평창올림픽
  • 코로나19
  • 2020도쿄올림픽
  • 게시판찾기
  • 오유인페이지
    개인차단 상태
    꾸오와앙님의
    개인페이지입니다
    가입 : 12-03-25
    방문 : 1890회
    닉네임변경 이력
    회원차단
    회원차단해제
    게시물ID : computer_87124
    작성자 : 내여친예쁘다
    추천 : 0
    조회수 : 480
    IP : 112.148.***.153
    댓글 : 5개
    등록시간 : 2013/05/07 14:27:39
    http://todayhumor.com/?computer_87124 모바일
    c++ 프로그래밍 질문좀 해도될까요...

    안녕하세요 오유님들

     

    프로그래밍을 공부하고 있는 컴공 학부생입니다...

     

    이번 과제가 레드블랙 트리를 구축하는 것인데요.

     

    일단 이진탐색트리를 먼저 만들고 그 다음에 레드블랙 트리로 발전시켜나가려고하는데

     

    이진탐색트리 구현과정에 막히는 부분이 있네요...

     

    자식노드와 부모노드가 상호참조하게 하고 싶은데

     

    현재 작성한 코드는 부모노드에서 자식노드로 가는 포인터만 존재하고 있습니다...

     

    일단 코드 일부분만 올려볼게요.

     

    #include <iostream>
    #include <string>

    using namespace std;

    class TreeNode{ // 노드 클래스
     friend class Tree;
    public:
     TreeNode( const int &d ) // 노드 생성자. 서브트리를 생성한다.
      : leftPtr( 0 ), data( d ), rightPtr( 0 ) // 자기자신은 입력받은 데이터로 초기화, 왼쪽 자식과 오른쪽 자식 생성
     {
      
     }
    private:
     TreeNode *leftPtr; // 왼쪽 자식 포인터
     TreeNode *rightPtr; // 오른쪽 자식 포인터
     TreeNode *parPtr; // 부모 포인터
     int data; // 노드에 들어갈 데이터
     //int maxheight;

     enum { red, black } color;
    };

    class Tree{ // 트리 클래스
    public:
     Tree(); // 트리 생성자
     void insertNode( const int & ); // 입력 함수. insertNodeHelper를 호출한다.
     void inOrderTraversal() const; // 중위순회 함수. inOrderHelper를 호출한다.
     void SearchNode( const int & ); // 탐색 함수. SearchNodeHelper를 호출한다.
     //void TestHeight();
    private:
     TreeNode *rootPtr; // 루트 노드 포인터

     void insertNodeHelper( TreeNode **, const int & ); // 입력 함수
     void inOrderHelper( TreeNode * ) const; // 중위순회 함수
     void SearchNodeHelper( TreeNode *, const int & ); // 탐색 함수

     void reColoring();
     void reStructuring();

     //높이 함수
     //void HeightHelper( TreeNode *, int &, int &, int & );

     void AVLstructuring();
     
    };

    Tree::Tree(){ // 트리를 생성함과 동시에 루트노드의 포인터를 0(External) 으로 초기화 한다.
     rootPtr = 0;
    }

    void Tree::insertNode( const int &value ){ // 입력 함수. main에서 데이터를 받아온다.
     insertNodeHelper( &rootPtr, value );
    }

    void Tree::insertNodeHelper( TreeNode **ptr, const int &value ){
     if ( *ptr == 0 ){ // 현재 가리키고 있는 노드가 External 노드이면 새로운 노드를 하나 생성한다.
      *ptr = new TreeNode( value ); // 노드 생성시 main에서 입력 받은 데이터로 초기화한다.
      // 부모노드의 주소를 현재 노드의 parPtr에 저장해야함.
      cout << value << " 가 입력되었습니다." << endl;
     }
     else{ // 현재 가리키고 있는 노드가 internal 노드일 때 External 노드를 찾아간다.
      if ( value < (*ptr)->data ){ // 입력받은 값이 현재 노드의 데이터 값보다 작으면 왼쪽 노드를 확인한다.
       insertNodeHelper( &((*ptr)->leftPtr), value );
      }
      else{ // 입력받은 값이 현재 노드의 데이터 값보다 크면 오른쪽 노드를 확인한다.
       if ( value > (*ptr)->data ){
        insertNodeHelper( &((*ptr)->rightPtr), value );
       }
       else // 입력 받은 값이 이미 트리에 있으면 메세지 출력
        cout << value << "는 이미 존재하는 값입니다." << endl;
      }
     }
    }

    이게 코드 일부분이고 주요한 부분은 빨간색으로 색칠해놨어요.

     

    제멋대로 코드라서 해석하기 힘드실 것같네요...

     

    그래도 과제여서 혼자 힘으로 해보려고했는데 도저히 저부분에서 막혀서 진도가 나가지 않아서

     

    조언좀 얻고자 이렇게 도움을 청해봅니다...

     

    프로그래밍 고수님들의 조언 부탁드립니다ㅠㅠ


    이 게시물을 추천한 분들의 목록입니다.
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

    죄송합니다. 댓글 작성은 회원만 가능합니다.

    번호 제 목 이름 날짜 조회 추천
    21
    윈도우 10으로 업그레이드 한 뒤 키보드가 이상합니다. 꾸오와앙 16/07/23 17:01 37 0
    20
    플레투스 나눔합니다. 꾸오와앙 16/01/20 16:35 36 3
    18
    ㅅㅅ와 사랑나누기의 차이 [2] 내여친예쁘다 14/08/14 00:33 377 6/4
    17
    sqlite 테이블 컬럼수 제한 있나요? [3] 내여친예쁘다 14/06/02 20:28 17 0
    16
    php 에서 mysql 데이터 받아올때 내용이 바뀌는것에 대한 질문입니다 [3] 내여친예쁘다 14/05/14 23:53 17 0
    15
    우분투 네트워크 설정 에러 문제.... [1] 내여친예쁘다 14/05/07 23:56 27 0
    14
    신발 커스텀해보신분 계신가요? 내여친예쁘다 14/04/19 11:27 0 0
    13
    여친이 똥사진을 보내줬어요. [5] 내여친예쁘다 13/11/24 02:55 83 1
    12
    노트북 유선랜이 안잡히고 무선랜이 잡혀요... 내여친예쁘다 13/11/23 22:55 27 0
    11
    visual studio 2008 에 대한 질문입니다. [1] 내여친예쁘다 13/06/18 13:20 19 0
    10
    프로그래밍 질문 있습니다.. 객체를 배열에... [2] 내여친예쁘다 13/06/10 15:32 42 0
    9
    c++ 프로그래밍 형변환 질문입니다. [1] 내여친예쁘다 13/06/09 21:49 20 0
    8
    다크네이비 정장에는 어떤 셔츠, 넥타이, 구두 조합이 좋나요? [3] 내여친예쁘다 13/05/30 11:01 25 0
    7
    c++ 프로그래밍 오류좀 여쭤보고 싶습니다.(레드블랙트리) [6] 내여친예쁘다 13/05/12 16:30 49 0
    c++ 프로그래밍 질문좀 해도될까요... [3] 내여친예쁘다 13/05/07 14:27 44 0
    5
    아르바이트 중도퇴사에 대한 임금 지불 문제 [1] 내여친예쁘다 13/04/05 10:55 12 0
    4
    컴퓨터가 잘 되다가 꺼지는데 뭐가 문제일까요? [3] 내여친예쁘다 13/01/04 18:08 30 0
    3
    하드 부팅 질문이요 급합니다 ㅠㅠㅠ 내여친예쁘다 12/12/21 13:09 12 0
    2
    이정도면 치킨 먹나요??? [3] 내여친예쁘다 12/07/12 00:08 469 0
    1
    오유에 게이라고 드립치시는 분들 내여친예쁘다 12/07/02 00:57 34 0
    [1]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈