[완료]스택의 용도가 어떤건가요?
글쓴이: jephir / 작성시간: 월, 2010/03/29 - 10:57오후
그냥 간단한... 기초적인 질문인데요
스택의 용도가 궁금하네요 =_=;
자료구조중에 하나이고 후입선출인것도 아는데
그냥 그런 자료구조라는것만 알고...
이걸 어디에 써먹어야되고, 어떻게 써먹어야할지 잘 감이 안오네요.
제가 아는거라곤
postfix연산할때 쓰고..
backtracking할때도 쓰고...
뭐 비슷하게 트리에서 최단거리 알고리즘중에 하나로도 써먹는거정도?
문제가 주어졌을때 이건 이런거라서 스택의 이런
기능을 사용해서 풀면 된다.. 라는식의 그런게 어떤걸까요? =_=;;
저번에 지뢰찾기 프로그램을 만들때 스택을 이용하면 구현할수 있다고
그러길래 계속 고민고민 해봤는데 재귀...밖에 팍 떠오르는게 없고...
스택으로 어떻게 써먹어야할지 감이 안오고...
이러니까 스택의 특성이 뭐고 용도가 어떤건지 내가 아는게 없다고 느껴지더라구요 =_=;;
Forums:
만들고 계신
만들고 계신 프로그램이 모두 스택으로 동작됩니다.
유저모드에서만 봐도, main() -> function foo() -> function bar() ->... 와 같이 동작되지요.
음... 그거말고
음... 그거말고 자료구조와 알고리즘 개념에서
스택을 이용함으로써 얻어지는 이득? 스택을 사용해야하는 문제가 어떤것? 이랄까
그런걸 고민중이었는데요 =_=;;
^^
생각하신 재귀(Recursive) 호출을 반복문(Iterative)으로 만들어보세요. 스택을 사용하시게 될겁니다.
-----------
청하가 제안하는 소프트웨어 엔지니어로써 재미있게 사는 법
http://sozu.tistory.com
-----------
청하가 제안하는 소프트웨어 엔지니어로써 재미있게 사는 법
http://sozu.tistory.com
그냥 만드는 사람이
그냥 만드는 사람이 개념을 단순화시키기 위해 쓴다-라고 보시면 되겠죠
예를들어 스택이 있어야될 자리에 데크가 있다거나 링크드리스트가 있다거나.. 스택이 할수있는 일을 전부 할수있는 자료구조는 많고 이런거 넣어도 하등 문제될거 없습니다(아마 이 부분이 잘 이해가 안되신다는것 같은데) 그런데 굳이 스택을 쓰는건 일단 만드는 쪽에서도 '여기는 스택만으로 할수있는 일' 이라는 표시가 되는 명료함이 있고 코드를 보는 쪽에서도 스택이 들어갔다는 것만으로 유추할 수 있는 게 늘어나죠
스택이란거 자체가 소프트웨어 관점에서만 보면 원래 되는걸 굳이 안되게 막아놓은 쪽에 가까우니까요. (링크드리스트는 중간 삽입, 삭제가 되는데 리스트로 스택을 구현하면 그런거 없죠 그냥 push, pop만...)
굳이 비교하자면 C++에서 모든 클래스 멤버를 다 public으로 하면 편할텐데 왜 굳이 private라는 개념을 넣어서 더 불편하게 만드느냐.. 와 비슷한 이유라고 생각됩니다.
========================
귀엽고 깜찍한 호빵님~ >ㅁ<
오홍
오홍 감사합니다!
뭔가 확 와닿네요 ㅋㅋ
댓글 달기