C로 자료구조/알고리즘 공부하려고 하는데요
글쓴이: waltherppk / 작성시간: 수, 2003/04/30 - 6:42오후
책은 오라일리의 "Algorithm with C" 번역판을 택했는데요
자료구조를 어떻게 구현한다는 것은 대충 알 것도 같은데
어떻게 사용하는 것인지는 그림이 안그려지네요.
좀더 예제가 많은 책이나 사이트 없을까요 ?
Java만 갖고 흔들어대다가, C도 알아야할 것 같아서 시작했는데요
Java에서는 컬렉션 객체를 생성해서 집어넣으면 되었는데
C에서는 그런게 아니니까 좀 혼란스럽습니다.
자료구조 헤더파일을 여러군데서 include하면 각각 따로 관리 되나요 ?
그리고
하나의 파일에서 여러개의 자료구조를 생성하는게 가능한가요?
객체지향에서는 그냥 다른이름으로 객체를 생성하면 되지만
여기서는 전혀 그림이 안그려지네요
Java에서는 여러개의 파일을 만든다음에
각 파일을 객체로 생성해서 쓰게되니까 머릿속으로 포장하는게 되는데
C은 그게 잘 안되요.
그리고 이렇게 Java를 바탕으로 다른 언어를 비교해가면서 공부하는 것이
적절한 접근법인지도 궁금합니다.
그리고 C에서는 Java의 컬렉션api 같은거 없나요 ?
물론 무료로 쓸 수 있는 걸로요.
Forums:
C로 배우는 알고리즘.
이 책 추천입니다. ^^
뭐.. 저도 알고리즘 공부할때 봤었죠
조금 오래된 책이긴하지만..
( 명서-_-a는 오래가는법이죠 ㅎㅎ )
바람과 같이
Re: C++로 공부하시는게 어떠실지...
자바에 익숙하신 사용자시라면 C보다는
객체지향 언어인 C++을 하시는 게 좋을텐데요.
C++ 표준 라이브러리에는 JDK의 컬렉션 API보다 훨씬 강력한 STL(Standard Template Library)이 포함되어 있습니다.
STL은 객체지향(OOP)과는 다른 패러다임인 제너릭 프로그래밍(generic programming)을 따르는 라이브러리로서, 동적 배열(vector, deque), 연결 리스트(list, slist), 이진 탐색 트리(set, map), 해쉬 테이블(hash_set, hash_map), 문자열(string, rope) 등의 컨테이너(container)와 스택, 큐, 우선순위 큐와 같은 컨테이너 어댑터(container adapter), 컨테이너에 적용하는 100가지가 넘는 각종 알고리듬, 컨테이너와 알고리듬을 연결하여 동작시키는 반복자(iterator) 등의 다양한 기능을 가지고 있습니다.
이러한 STL을 제대로 사용하려면 당연히 자료구조와 알고리듬에 대한 이해가 필요합니다.
댓글 달기