데이터 구조 및 알고리즘: 스택
8674 단어 dsalgo
data:image/s3,"s3://crabby-images/9df4b/9df4bc37abff5d86b7f4120f46c0451a6292a2d4" alt=""
하나 추가....
data:image/s3,"s3://crabby-images/828da/828da9537a3b02f6c9b8db8a6d89823173e7ef47" alt=""
또 하나 추가...
data:image/s3,"s3://crabby-images/e7c41/e7c41a90fb48625e34b94beccef25d95eda8ae53" alt=""
하나 더 추가..
data:image/s3,"s3://crabby-images/7f96d/7f96d2e9c8e571bff6dcab09328cae96f5db3abb" alt=""
이제 문제는 우리가 한 그릇을 밖에 가져가서 어떤 그릇을 먼저 가져갈지 추측할 수 있다는 것입니다.
3번째인가요? 두 번째? 아니면 1위?
예, 세 번째이며 LIFO(Last In First Out)를 따릅니다.
data:image/s3,"s3://crabby-images/9a12b/9a12b51d1d778e7e8bf441f0bc5d2011388c4c57" alt=""
그럼 이렇게 제거해보겠습니다
data:image/s3,"s3://crabby-images/d496a/d496a2b6c62547316c53e712678e2a3a2f2a4ed4" alt=""
data:image/s3,"s3://crabby-images/b158d/b158d87ccde3bff3b63f2ac093aebcf19768be34" alt=""
data:image/s3,"s3://crabby-images/8bac3/8bac3cb5c33d3c99be6767ca2e0fe0220542483e" alt=""
따라서 연결된 목록을 사용하여
data:image/s3,"s3://crabby-images/4e399/4e39917756fda1e64b9cc0366a691a79b1c58611" alt=""
아이템 팝
data:image/s3,"s3://crabby-images/c0fd6/c0fd68148e323e6d815b5367a2b7b4b7c2cecac8" alt=""
또한 앞에 붙일 수 있습니다
data:image/s3,"s3://crabby-images/4e399/4e39917756fda1e64b9cc0366a691a79b1c58611" alt=""
스택은 다음과 같습니다.
data:image/s3,"s3://crabby-images/17aba/17aba6312bb029ea24790cb6f24d309c8c041cd8" alt=""
건설자
먼저 노드 생성
data:image/s3,"s3://crabby-images/1e7f5/1e7f5e31f3cf633b10860c70693aeaa031c33244" alt=""
첫 번째 노드 만들기
data:image/s3,"s3://crabby-images/24962/24962227a16d5bbb4df5e8eca2a47ecb9e96589e" alt=""
다음과 같이 상단 및 하단을 설정합니다.
data:image/s3,"s3://crabby-images/6fcdd/6fcddce146a8a5d8636adbd7c585a4312912603e" alt=""
우리는 바닥에 신경쓰지 않고 따라서 바닥을 제거할 것입니다.
data:image/s3,"s3://crabby-images/f2af2/f2af2e509381acb79907d8f87cde0a8ddd257fd4" alt=""
data:image/s3,"s3://crabby-images/bc578/bc5784918ecc51cbc64ffb7b94999e39cc16b295" alt=""
따라서 전체적으로 생성자는 다음과 같습니다.
data:image/s3,"s3://crabby-images/9bf2e/9bf2e1e750a8652ead592639b847dccbc775cc78" alt=""
이에 대한 코드:
#Node class : Creates node
class Node:
def __init__(self, value):
self.value = value
self.next = None
#Creates a stack class
class Stack:
def __init__(self, value):
#creates a node by calling the Node class
new_node = Node(value)
#pointing the top to that node
self.top = new_node
#adding the length to 1
self.height = 1
#Prints the stack untill it finds None
def print_stack(self):
temp = self.top
while temp is not None:
print(temp.value)
temp = temp.next
#Creating a stack with node 4
my_stack = Stack(4)
#Printing the stack
my_stack.print_stack()
푸시
사례 1:
스택이 비어 있으면 노드를 추가하고 맨 위에 할당합니다.
data:image/s3,"s3://crabby-images/bfe9e/bfe9ef4665760cc54353f126e4233b72fa10c8cb" alt=""
data:image/s3,"s3://crabby-images/a6962/a6962124193a26316048225fde7f5154d6fa88ee" alt=""
사례 2:
이전 스택에 노드를 추가합니다.
data:image/s3,"s3://crabby-images/22436/22436d2697043830dce240f0381fb61325441a9b" alt=""
data:image/s3,"s3://crabby-images/bf271/bf27182aba59173d9871a1e6d03e57a017799cbc" alt=""
data:image/s3,"s3://crabby-images/e3b34/e3b343ef93d8fdeb893a4384c0055f77fd9c173e" alt=""
이에 대한 코드:
class Node:
def __init__(self, value):
self.value = value
self.next = None
class Stack:
def __init__(self, value):
new_node = Node(value)
self.top = new_node
self.height = 1
def print_stack(self):
temp = self.top
while temp is not None:
print(temp.value)
temp = temp.next
#push method
def push(self, value):
new_node = Node(value)
#When there are no nodes in the stack
if self.height == 0:
self.top = new_node
#When there are nodes in the stack
else:
new_node.next = self.top
self.top = new_node
self.height += 1
#Creates a stack of 2
my_stack = Stack(2)
#pushing 1 to the stack
my_stack.push(1)
my_stack.print_stack()
팝
사례: 1
스택에 아무 것도 없으면 아무 것도 반환하지 않습니다.
data:image/s3,"s3://crabby-images/248aa/248aae0f15e1f9108ed5a67c538c2d31a8845738" alt=""
사례 2:
스택이 있고 마지막으로 입력한 값을 반환할 때.
먼저 온도를 설정합니다.
data:image/s3,"s3://crabby-images/6a970/6a970196c05f74115740065bc83265090df056f9" alt=""
그 다음에
data:image/s3,"s3://crabby-images/cce87/cce87cbdfb8d035ce542a99e94a1ae40908212df" alt=""
data:image/s3,"s3://crabby-images/756d9/756d9c29b0030a7dd7d29b79a6e72fbc2a6639dd" alt=""
class Node:
def __init__(self, value):
self.value = value
self.next = None
class Stack:
def __init__(self, value):
new_node = Node(value)
self.top = new_node
self.height = 1
def print_stack(self):
temp = self.top
while temp is not None:
print(temp.value)
temp = temp.next
def push(self, value):
new_node = Node(value)
if self.height == 0:
self.top = new_node
else:
new_node.next = self.top
self.top = new_node
self.height += 1
return True
def pop(self):
#when we have no nodes in the stack
if self.height == 0:
return None
#when we have nodes in the stack
temp = self.top
self.top = self.top.next
temp.next = None
self.height -= 1
return temp
#A stack of nodes 7,23,3,11
my_stack = Stack(7)
my_stack.push(23)
my_stack.push(3)
my_stack.push(11)
#poping a node from the stack. Note: pop returns the last value intered into the stack[last in first out]
print(my_stack.pop(), '\n')
my_stack.print_stack()
data:image/s3,"s3://crabby-images/d024c/d024cd4058691acd83f6586a11d8a0de991fab11" alt=""
Reference
이 문제에 관하여(데이터 구조 및 알고리즘: 스택), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/mitul3737/stack-39j텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)