inflearn logo
강의

Course

Instructor

Open Source Data Structures and Algorithms in C

Binary Serach Tree insert function 2

Insert_data에서 prev_tmp를 지웠을 때, 성능향을 기대할 수 있을까요?

202

Kumma

6 asked

0

제 생각으로는 성능 향상이 거의 없다고 생각이 되는데, 궁금합니다!

1 . 트리의 특성 상, Insert 내의 While() 1번은 사실 상 2^n개의 데이터를 순회하는 효과니까 데이터가 정말 많아도 100번 이하로 돌 것 같습니다.

2. 대입문 1개는 지우는건 어셈블리 1줄을 지우는 거니까, 100줄 정도의 어셈이 사라지는 것인데, 이게 큰 성능향상인지 궁금합니다!

c linux 알고리즘 gcc data-structure

Answer 1

1

jikim1770

안녕하세요.

tree 의 insert_data 함수의 개선 과정을 문의 하신 것 같습니다.

 

해당 소스를 보면

	if( root == 0 )
	{
		root = temp;
		return;
	}
	while(p)
	{
		prev = p;
		if( p->data > data )
			p=p->left;
		else if( p->data < data )
			p=p->right;
		else
			return;
	}
	if( prev->data > data )
		prev->left = temp;
	else
		prev->right = temp;

위 부분이 아래와 같이 바뀐 것이므로

	while(*p)
	{
		if( (*p)->data > data )
			p=&(*p)->left;
		else if( (*p)->data < data )
			p=&(*p)->right;
		else
			return;
	}
	*p = temp;

while 루프 안의

prev = p 가 사라진 것과

 

while 아래 쪽의 if ~ else 구문이 사라진 것이 주요 합니다.

 

while 루프 안의 코드 삭제는 log N 번 이라 하더라도 데이터가 많은 경우 성능 향상을 기대할 수 있습니다.

 

또한 While 아래쪽의 if ~ else 또한 while 안쪽은 아니지만 insert_data 함수가 여러 번 호출 되었을 때 성능상 이점이 되리라 생각 됩니다.

수강평 이벤트

0

15

2

안녕하세요. 계속 프로젝트를 해야지 하다가 결제하고 환경 설정 중입니다.

0

13

1

Export template 안됨

1

26

2

part8 Notion 링크

0

22

1

scanf("%d\n") 의미

0

20

1

필기자료 사라졌나요?(실기 일주일만에 안돼서 재도전-_-)

0

37

2

26년 1회 실기 해설 강의

0

51

2

잠겨버린 사물함 시간초과 관련 질문입니다.

0

25

1

프로젝트 질문 문의

0

45

1

주소 연산자(&) 간접 지정자(*) 반대 개념

0

33

1

53번 4-1 자료 오류 있는 것 같습니다.

0

68

2

7번문제

0

57

2

C언어 변형문제 9번문제 Pdf 수정요청

0

45

2

메서드 오버드라드

0

45

2

실수

0

45

1

공부 우선순위 우선강의 알려주세요

0

85

1

생성자 호출순서 강의 10번 문제 30분대 질문입니다

0

46

2

25년 2회 기출 5:40 질문입니다.

0

39

2

C언어 출제변형 6번 문제

0

50

2

c언어 출제변형 강의 질문

0

31

2

vi 명령어

0

46

1

tail노드의 이유 & 메모리 풀링 관련

0

324

2

커널 버전

0

251

1

메모리 풀링 속도 확인

0

327

1