• 목록
  • 아래로
  • 위로

안녕하세요?


프로그래머스 코딩테스트 연습이 전반적으로 예전보다 효율성 심사가 강화되었다고 알고 있는데요.


제가 알고리즘 인강을 수강하고는 있지만 아직 실력이 부족해서 효율성 심사에서 걸리는 경우가 많더군요.



제 짧은 생각으로는 선형탐색보다는 이진탐색이 바람직할 것 같구요.


재귀함수 등을 사용하지 않는 방향으로 해서 함수 호출을 최소화하는 것이 효율적일 것으로 생각되구요.


몇몇 풀이를 보니 리스트의 원소를 remove 하는 방식도 피해야 할 것 같은데요. 



제가 아직 알고리즘의 복잡도(Complexity of Algorithms)란 개념에 대해서 충분히 파악하지 못하고 있는 것 같은데요.


어떤 방향으로 코딩을 하는 것이 효율성 측면에서 바람직한지, 


그리고 어떤 서적이나 인강으로 공부를 하면 효율적인 알고리즘을 구현할 수 있는지 여쭤봅니다 ^^


구글링해보면 프로그래머스 코딩테스트의 개별적인 문제풀이에서의 효율성을 높이는 방식은 찾을 수 있던데


물론 구체적인 사안도 궁금하지만, 알고리즘의 전반적인 측면에서 질문을 드립니다.


그럼 즐겁고 뜻깊은 연말 되세요!


답변해주실 고수님들께 미리 감사드립니다 :)

작성자
이니스프리 119 Lv. (2%) 4189480/115200000EXP

Make StudyForUs Great Again!

 

CSVpuymXAAAVVpd.jpg

댓글 2

title: 황금 서버 (30일)humit
profile image

아무래도 자료구조에 대한 이해가 가장 중요합니다. 어떤 자료형을 쓰느냐에 따라서 수행 시간이 천차만별로 달라지거든요.

예를 들어 ArrayList와 LinkedList가 있는데, 추가/삭제를 하는 경우에 ArrayList는 느리지만 LinkedList는 빠릅니다. 반면 인덱스 조회를 하는 경우에 대해서는 ArrayList는 빠르지만 LinkedList는 느립니다.

특히 노드에서의 최단거리를 찾는 알고리즘인 다익스트라 알고리즘의 경우에 어떤 자료형을 쓰느냐에 따라서 시간 복잡도가 달라집니다.

 

다만 특수하게 사용되는 자료형들이 있어서 이 경우에는 모르면 풀지 못하는 경우가 있습니다. 예를 들어 2020년 카카오 블라인드 1차 테스트의 경우 효율성 테스트를 통과하기 위해선 trie라는 특수한 자료형을 사용할 필요가 있습니다.

 

이렇게 전반적인 자료형에 이해를 하시고 나면 그 후에 Big-O notation이라고 하는 방식으로 대략적인 수행시간을 계산합니다. 보통 10^9 이하로 나오면 안전하다고 보시면 되겠습니다.

comment menu
2019.12.25. 13:36

신고

"humit님의 댓글"

이 댓글을 신고 하시겠습니까?

이니스프리 작성자 → humit
profile image

즐거운 크리스마스 보내고 계시는지요?

휴일인데 답변해주셔서 감사합니다 ^^

 

역시 자료구조가 중요하군요~!

연말이라 무리를 했는지 병원 신세를 지고 있어서, 요새 알고리즘 인강을 수강 못 하고 있거든요 ㅠㅠ

더 공부를 해야 humit 님께서 말씀해주신 내용을 완전히 이해할 수 있을 것 같네요.

Big-O notation에 대한 부분도 인강에서 언급하던데 아직 개념을 완전히 파악하지 못했네요.

앞으로 자료구조에 대한 공부를 더 하겠습니다~

 

그럼 뜻깊은 연말 되세요!! 감사합니다 ^-^

comment menu
2019.12.25. 13:45

신고

"이니스프리님의 댓글"

이 댓글을 신고 하시겠습니까?

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 시스템 점검 작업 완료 안내 10 마스터 24.09.05.16:25 2620
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 23.01.14.02:23 10077
공지 [필독] 질문하는 방법 17 마스터 18.02.23.03:09 4946
286 Crontab에서 파이썬 실행이 시간적으로 겹치는 것과 관련하여 질문 드립니다 ^^ 이니스프리 19.12.06.01:06 1435
285 프로그래머스의 코딩테스트 연습과 COS PRO 난이도에 대해 질문 드립니다. 5 이니스프리 19.12.08.22:26 516
284 머신러닝 오프라인 강좌를 수강해보려고 하는데요~ 이거 괜찮을까요? 5 image 이니스프리 19.12.11.03:12 532
283 논논비요리 만화책을 보려고 하는데 일본어를 얼마나 공부해야 될까요? 4 image 이니스프리 19.12.15.16:38 498
프로그래머스 코딩테스트 연습에서 효율성 심사를 통과하려면 어떻게 해야할까요? 2 이니스프리 19.12.18.01:55 2917
281 [Requests] multipart/form-data의 전송에 대해 질문 드립니다 ^^ 4 이니스프리 19.12.18.22:00 3176
280 부산 맛집 추천 부탁드려요~! 3 image 이니스프리 19.12.20.19:00 230
279 Google Developer Console의 API 라이브러리 무료 이용에 대해 질문 드립니다. 5 image 이니스프리 19.12.23.12:58 297
278 https://imgnbvip.com/ 라는 이미지 호스팅 사이트가 있나요? image 이니스프리 19.12.24.11:08 302
277 음성번역기 앱 중에 켜놓으면 계속 번역을 해주는 앱이 있을까요? 이니스프리 19.12.25.11:16 305
276 [파이썬] 결과를 print 문으로 출력하는 것과 파일로 출력하는 것과 결과가 왜 다른가요? 8 image 이니스프리 19.12.25.13:19 828
275 카고야 VPS에서 메일이 왔는데 일본어 관련해서 질문 드립니다. 5 이니스프리 19.12.26.11:45 330
274 Requests나 Selenium에서 어떤 XHR 전송이 있었는지 확인할 수 있는 방법이 있을까요? 3 이니스프리 19.12.26.18:47 315
273 유튜브 채널 주소 잘아시는분있나요? 2 슬기 19.12.27.09:55 210
272 여러 개의 반복작업을 켜고 끄는 버튼을 비동기적으로 구현해보려고 하는데요 ㅠㅠ 2 이니스프리 19.12.27.23:10 652
271 [파이썬] 윈도우에서 pip install로 모듈 설치시에 문제가 발생하는 것과 관련하여 질문 드립니다 2 이니스프리 19.12.29.00:51 427
270 [Selenium] 특정 XPath에서 parent 노드의 iframe을 알아낼 수 있을까요? 2 이니스프리 20.01.02.16:04 680
269 Beautifulsoup에서 .find(text=True, recursive=False)과 관련하여 질문 드립니다. 2 이니스프리 20.01.03.23:11 1214
268 해상도는 다르지만 동일한 이미지인지 체크하는 방법이 있을까요? 2 이니스프리 20.01.05.20:52 615
267 이미지 외부링크가 엑박으로 나온다면 어느 부분을 우선적으로 검토해야 될까요? 이니스프리 20.01.05.23:15 670