1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
#include <stdio.h>
#include <stdlib.h>
 
typedef int element;
typedef struct TreeNode {
    element key;
    struct TreeNode *left, *right;
} TreeNode;
 
// ¼øȯÀûÀΠŽ»ö ÇÔ¼ö
TreeNode * search(TreeNode * node, int key)
{
    if (node == NULLreturn NULL;
    if (key == node->key) return node;
    else if (key < node->key)
        return search(node->left, key);
    else
        return search(node->right, key);
}
TreeNode * new_node(int item)
{
    TreeNode * temp = (TreeNode *)malloc(sizeof(TreeNode));
    temp->key = item;
    temp->left = temp->right = NULL;
    return temp;
}
TreeNode * insert_node(TreeNode * node, int key)
{
    // Æ®¸®°¡ °ø¹éÀ̸頻õ·Î¿î ³ëµå¸¦ ¹ÝȯÇÑ´Ù. 
    if (node == NULLreturn new_node(key);
 
    // ±×·¸Áö ¾ÊÀ¸¸é ¼øȯÀûÀ¸·Î Æ®¸®¸¦ ³»·Á°£´Ù. 
    if (key < node->key)
        node->left = insert_node(node->left, key);
    else if (key > node->key)
        node->right = insert_node(node->right, key);
 
    // º¯°æµÈ ·çÆ® Æ÷ÀÎÅ͸¦ ¹ÝȯÇÑ´Ù. 
    return node;
}
TreeNode * min_value_node(TreeNode * node)
{
    TreeNode * current = node;
 
    // ¸Ç ¿ÞÂÊ ´Ü¸» ³ëµå¸¦ Ã£À¸·¯ ³»·Á°¨
    while (current->left != NULL)
        current = current->left;
 
    return current;
}
// ÀÌÁø Å½»ö Æ®¸®¿Í Å°°¡ ÁÖ¾îÁö¸é Å°°¡ ÀúÀåµÈ ³ëµå¸¦ »èÁ¦ÇÏ°í 
// »õ·Î¿î ·çÆ® ³ëµå¸¦ ¹ÝȯÇÑ´Ù. 
TreeNode * delete_node(TreeNode * root, int key)
{
    if (root == NULLreturn root;
 
    // ¸¸¾à Å°°¡ ·çÆ®º¸´Ù ÀÛÀ¸¸é ¿ÞÂÊ ¼­ºê Æ®¸®¿¡ Àִ °ÍÀÓ
    if (key < root->key)
        root->left = delete_node(root->left, key);
    // ¸¸¾à Å°°¡ ·çÆ®º¸´Ù Å©¸é ¿À¸¥ÂÊ ¼­ºê Æ®¸®¿¡ Àִ °ÍÀÓ
    else if (key > root->key)
        root->right = delete_node(root->right, key);
    // Å°°¡ ·çÆ®¿Í °°À¸¸é ÀÌ ³ëµå¸¦ »èÁ¦Çϸ頵Ê
    else {
        // Ã¹ ¹ø°³ª µÎ ¹ø° °æ¿ì
        if (root->left == NULL) {
            TreeNode * temp = root->right;
            free(root);
            return temp;
        }
        else if (root->right == NULL) {
            TreeNode * temp = root->left;
            free(root);
            return temp;
        }
        // ¼¼ ¹ø° °æ¿ì
        TreeNode * temp = min_value_node(root->right);
 
        // Áß¿Ü ¼øȸ½Ã ÈÄ°è ³ëµå¸¦ º¹»çÇÑ´Ù. 
        root->key = temp->key;
        // Áß¿Ü ¼øȸ½Ã ÈÄ°è ³ëµå¸¦ »èÁ¦ÇÑ´Ù. 
        root->right = delete_node(root->right, temp->key);
    }
    return root;
}
 
// ÁßÀ§ ¼øȸ
void inorder(TreeNode * root) {
    if (root) {
        inorder(root->left);// ¿ÞÂʼ­ºêÆ®¸® ¼øȸ
        printf("[%d] ", root->key);  // ³ëµå ¹æ¹®
        inorder(root->right);// ¿À¸¥Âʼ­ºêÆ®¸® ¼øȸ
    }
}
 
int main(void)
{
    TreeNode * root = NULL;
    TreeNode * tmp = NULL;
 
    root = insert_node(root, 30);
    root = insert_node(root, 20);
    root = insert_node(root, 10);
    root = insert_node(root, 40);
    root = insert_node(root, 50);
    root = insert_node(root, 60);
 
    printf("ÀÌÁø Å½»ö Æ®¸® ÁßÀ§ ¼øȸ °á°ú \n");
    inorder(root);
    printf("\n\n");
    if (search(root, 30!= NULL)
        printf("ÀÌÁø Å½»ö Æ®¸®¿¡¼­ 30À» ¹ß°ßÇÔ \n");
    else
        printf("ÀÌÁø Å½»ö Æ®¸®¿¡¼­ 30À» ¹ß°ß¸øÇÔ \n");
    return 0;
}
cs