모바일 오유 바로가기
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
    조회수 : 481
    IP : 112.148.***.153
    댓글 : 5개
    등록시간 : 2013/05/07 14:27:39
    http://todayhumor.com/?computer_87124 모바일
    c++ 프로그래밍 질문좀 해도될까요...
    <P>안녕하세요 오유님들</P> <P> </P> <P>프로그래밍을 공부하고 있는 컴공 학부생입니다...</P> <P> </P> <P>이번 과제가 레드블랙 트리를 구축하는 것인데요.</P> <P> </P> <P>일단 이진탐색트리를 먼저 만들고 그 다음에 레드블랙 트리로 발전시켜나가려고하는데</P> <P> </P> <P>이진탐색트리 구현과정에 막히는 부분이 있네요...</P> <P> </P> <P>자식노드와 부모노드가 상호참조하게 하고 싶은데</P> <P> </P> <P>현재 작성한 코드는 부모노드에서 자식노드로 가는 포인터만 존재하고 있습니다...</P> <P> </P> <P>일단 코드 일부분만 올려볼게요.</P> <P> </P> <P>#include <iostream><BR>#include <string></P> <P>using namespace std;</P> <P>class TreeNode{ <SPAN style="COLOR: #22741c">// 노드 클래스</SPAN><BR> friend class Tree;<BR>public:<BR> TreeNode( const int &d ) <SPAN style="COLOR: #22741c">// 노드 생성자. 서브트리를 생성한다.</SPAN><BR>  : leftPtr( 0 ), data( d ), rightPtr( 0 ) <SPAN style="COLOR: #22741c">// 자기자신은 입력받은 데이터로 초기화, 왼쪽 자식과 오른쪽 자식 생성</SPAN><BR> {<BR>  <BR> }<BR>private:<BR> TreeNode *leftPtr; <SPAN style="COLOR: #22741c">// 왼쪽 자식 포인터</SPAN><BR> TreeNode *rightPtr;<SPAN style="COLOR: #22741c"> // 오른쪽 자식 포인터</SPAN><BR> <SPAN style="COLOR: #ff0000">TreeNode *parPtr; // 부모 포인터</SPAN><BR> int data; <SPAN style="COLOR: #22741c">// 노드에 들어갈 데이터</SPAN><BR><SPAN style="COLOR: #22741c"> //int maxheight;</SPAN></P> <P> enum { red, black } color;<BR>};</P> <P>class Tree{ <SPAN style="COLOR: #22741c">// 트리 클래스</SPAN><BR>public:<BR> Tree();<SPAN style="COLOR: #22741c"> // 트리 생성자</SPAN><BR> void insertNode( const int & ); <SPAN style="COLOR: #22741c">// 입력 함수. insertNodeHelper를 호출한다.</SPAN><BR> void inOrderTraversal() const; <SPAN style="COLOR: #22741c">// 중위순회 함수. inOrderHelper를 호출한다.</SPAN><BR> void SearchNode( const int & );<SPAN style="COLOR: #22741c"> // 탐색 함수. SearchNodeHelper를 호출한다.</SPAN><BR><SPAN style="COLOR: #22741c"> //void TestHeight();</SPAN><BR>private:<BR> TreeNode *rootPtr; <SPAN style="COLOR: #22741c">// 루트 노드 포인터</SPAN></P> <P> void insertNodeHelper( TreeNode **, const int & ); <SPAN style="COLOR: #22741c">// 입력 함수</SPAN><BR> void inOrderHelper( TreeNode * ) const;<SPAN style="COLOR: #22741c"> // 중위순회 함수</SPAN><BR> void SearchNodeHelper( TreeNode *, const int & ); <SPAN style="COLOR: #22741c">// 탐색 함수</SPAN></P> <P> void reColoring();<BR> void reStructuring();</P> <P> <SPAN style="COLOR: #22741c">//높이 함수</SPAN><BR><SPAN style="COLOR: #22741c"> //void HeightHelper( TreeNode *, int &, int &, int & );</SPAN></P> <P> void AVLstructuring();<BR> <BR>};</P> <P>Tree::Tree(){ <SPAN style="COLOR: #22741c">// 트리를 생성함과 동시에 루트노드의 포인터를 0(External) 으로 초기화 한다.</SPAN><BR> rootPtr = 0;<BR>}</P> <P>void Tree::insertNode( const int &value ){<SPAN style="COLOR: #22741c"> // 입력 함수. main에서 데이터를 받아온다.</SPAN><BR> insertNodeHelper( &rootPtr, value );<BR>}</P> <P>void Tree::insertNodeHelper( TreeNode **ptr, const int &value ){<BR> if ( *ptr == 0 ){ <SPAN style="COLOR: #22741c">// 현재 가리키고 있는 노드가 External 노드이면 새로운 노드를 하나 생성한다.</SPAN><BR>  *ptr = new TreeNode( value ); <SPAN style="COLOR: #22741c">// 노드 생성시 main에서 입력 받은 데이터로 초기화한다.</SPAN><BR><SPAN style="COLOR: #ff0000">  // 부모노드의 주소를 현재 노드의 parPtr에 저장해야함.</SPAN><BR>  cout << value << " 가 입력되었습니다." << endl;<BR> }<BR> else{ <SPAN style="COLOR: #22741c">// 현재 가리키고 있는 노드가 internal 노드일 때 External 노드를 찾아간다.</SPAN><BR>  if ( value < (*ptr)->data ){ <SPAN style="COLOR: #22741c">// 입력받은 값이 현재 노드의 데이터 값보다 작으면 왼쪽 노드를 확인한다.</SPAN><BR>   insertNodeHelper( &((*ptr)->leftPtr), value );<BR>  }<BR>  else{<SPAN style="COLOR: #22741c"> // 입력받은 값이 현재 노드의 데이터 값보다 크면 오른쪽 노드를 확인한다.</SPAN><BR>   if ( value > (*ptr)->data ){<BR>    insertNodeHelper( &((*ptr)->rightPtr), value );<BR>   }<BR>   else<SPAN style="COLOR: #22741c"> // 입력 받은 값이 이미 트리에 있으면 메세지 출력</SPAN><BR>    cout << value << "는 이미 존재하는 값입니다." << endl;<BR>  }<BR> }<BR>}<BR></P> <P>이게 코드 일부분이고 주요한 부분은 빨간색으로 색칠해놨어요.</P> <P> </P> <P>제멋대로 코드라서 해석하기 힘드실 것같네요...</P> <P> </P> <P>그래도 과제여서 혼자 힘으로 해보려고했는데 도저히 저부분에서 막혀서 진도가 나가지 않아서</P> <P> </P> <P>조언좀 얻고자 이렇게 도움을 청해봅니다...</P> <P> </P> <P>프로그래밍 고수님들의 조언 부탁드립니다ㅠㅠ</P>

    이 게시물을 추천한 분들의 목록입니다.
    푸르딩딩:추천수 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]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈