[C언어] Binary Tree (7) - smallestValue 함수 구현하기

2025. 4. 14. 17:07·크래프톤 정글/Code 정글(C언어)

Binary Tree (7) - smallestValue 함수 구현하기

이진 트리에서 가장 작은 값을 반환하는 함수

주어진 요소 확인하기

구조체

  • BTNode: (struct) 이진 트리 노드 구조체
    • item: (int field) 노드의 값
    • *left: (pointer field) 왼쪽 자식 노드 주소
    • *right: (pointer field) 오른쪽 자식 노드 주소
  • StackNode: (struct) 트리 생성을 위한 스택 노드 구조체
    • *btnode: (pointer field) 이진 트리 노드 주소
    • *next: (pointer field) 다음(스택 아래쪽) 노드 주소
  • Stack: (struct) 트리 생성을 위한 스택 구조체
    • *top: (pointer field) 스택 최상단 노드의 주소

smallestValue 함수의 매개 변수

  • *node: (pointer) 이진 트리 루트 노드 주소

 

핵심 아이디어

  • 각 노드마다 재귀적으로 가장 작은 값인지 확인
    • 노드가 NULL인 경우 INT_MAX 반환 (#include <limits.h> 필요)
    • 좌우 서브트리에서 가장 작은 값을 재귀적으로 구하기
    • 세 개의 값(해당 노드의 값, 좌우 서브트리의 가장 작은 값) 중 가장 작은 값을 반환

 

구현하기

#include <limits.h>  // INT_MAX를 사용하기 위해 필요

int smallestValue(BTNode *node) {
    // 노드가 NULL이면 아주 큰 값 반환
    if (node == NULL) return INT_MAX;

    // 왼쪽과 오른쪽 서브트리에서 최소값을 각각 재귀적으로 구하기
    int left = smallestValue(node->left);
    int right = smallestValue(node->right);

    // 세 값 중 가장 작은 값 결정
    int min = node->item;
    if (left < min) min = left;
    if (right < min) min = right;

    // 최종적으로 가장 작은 값을 반환
    return min;
}
저작자표시 비영리 변경금지 (새창열림)

'크래프톤 정글 > Code 정글(C언어)' 카테고리의 다른 글

[C언어] 이진 탐색 트리(Binary Search Tree) 구현 실습하기  (0) 2025.04.14
[C언어] Binary Tree (8) - hasGreatGrandchild 함수 구현하기  (0) 2025.04.14
[C언어] Binary Tree (6) - printSmallerValues 함수 구현하기  (0) 2025.04.14
[C언어] Binary Tree (5) - mirrorTree 함수 구현하기  (0) 2025.04.14
[C언어] Binary Tree (4) - sumOfOddNodes 함수 구현하기  (0) 2025.04.14
'크래프톤 정글/Code 정글(C언어)' 카테고리의 다른 글
  • [C언어] 이진 탐색 트리(Binary Search Tree) 구현 실습하기
  • [C언어] Binary Tree (8) - hasGreatGrandchild 함수 구현하기
  • [C언어] Binary Tree (6) - printSmallerValues 함수 구현하기
  • [C언어] Binary Tree (5) - mirrorTree 함수 구현하기
그냥사람_
그냥사람_
IT 관련 포스팅을 합니다. 크래프톤 정글 8기 정경호
  • 그냥사람_
    그냥코딩
    그냥사람_
  • 전체
    오늘
    어제
    • 글 전체보기
      • 크래프톤 정글
        • 로드 투 정글(입학시험)
        • CS기초(키워드, 개념정리)
        • 컴퓨터구조(CSAPP)
        • Code 정글(C언어)
        • 마이 정글(WIL, 에세이)
      • 자료구조&알고리즘
        • 자료구조
        • 알고리즘
      • 일상
  • 블로그 메뉴

    • 홈
  • 링크

    • Github
  • hELLO· Designed By정상우.v4.10.3
그냥사람_
[C언어] Binary Tree (7) - smallestValue 함수 구현하기
상단으로

티스토리툴바