CS/Python

[자료구조] 연결리스트와 트리 구조

Cori 2021. 11. 6. 13:21

1. 연결리스트 

0) 정의 

-> 각 노드가 데이터와 포인터를 가지고 한 줄로 연결되어 데이터를 저장하는 자료 구조 

1) 구현 

· 노드 구현 

class Node():
    def __init__(self, data):
        self.data = data 
        self.next = None

· 연결리스트 구현 

class LinkedList():
    def __init__(self):
        self.head = None 
        self.count = 0
        
    # 맨 앞에 데이터 추가 
    def appendHead(self, Node):
        if self.head == None:   # 연결리스트에 아무것도 없다면 
            self.head = node 
            self.count = 1
        else:
            self.count += 1 
            currentHead = self.Head
            self.head = node 
            node.next = currentHead 
            
    # 마지막에 데이터 추가 
    def append(self, node):
        if self.head == None:
            self.head = node
            self.count = 1 
        else:
            now = self.head
            while now.next != None:
                 now = now.next 
            now.next = node 
            self.count += 1
    
    # 특정 위치에 데이터 추가 
    def insertNode(self, node, index):
        if index < 0 or index > self.count:
            return -1 
        elif self.count == index:   # 리스트의 마지막에 데이터 추가 
            self.append(node)
        elif index == 0:   # 리스트의 가장 앞에 데이터 추가 
            self.appendHead(node)
        else:
            now = self.head
            while index > 0:
                index -= 1 
                now = now.next 
            self.count += 1 
            next = now.next 
            now.next = node
            node.next = next 
     
    # 데이터 삭제 
    def deleteData(self, data):
        if self.head.data == data:
            self.head = self.head.next 
            self.count -= 1 
        else:
            first = self.head
            second = first.next 
            while second != None:
                if second.data == data:
                    first.next = second.next 
                    self.count -= 1 
                    break
                first = second 
                second = second.next 

    # 연결리스트 데이터 개수 확인 
    def getCount(self):
        return self.count

2. 트라이 (Trie) 구조 

0) 정의

-> 문자열을 효율적으로 저장하고 탐색하기 위한 트리 형태의 자료 구조 

1) 구조

-> 문자열은 우리가 원하는 문자열로 시작할 수 있으며, 한 개의 트라이 구조의 가장 최상위 부모는 Null 값을 가짐 (Head)

2) 구현 

· 노드

class Node():
    def __init__(self, data):
        self.data = data
        self.children = {}

· 트라이 구조

class Trie():
    def __init__(self, data):
        self.head = Node(None)
        
    # 데이터 삽입 
    def insert(self, string):
        head = self.head
        for s in string:   
            children = head.children
            if s not in children:   # 존재 여부 검사
                children[s] = Node(s)
            head = children[s]

3) 활용 

· 추천검색어

-> 한 글자 한 글자 입력할 때 마다 이전 사용자들이 몇 번을 검색했는지에 대한 횟수를 가지고 있음.. 이를 활용하여 다음 문자 추천