오늘 한 일

  • 스터디에서 알고리즘 마라톤 문제를 6개 더 풀었다!(이미 풀어놨던 문제 2개 제외하고)
  • 오후 8시부터는 node.js에 대한 Q&A에 참여했다. 다른 분들과 달리 나는 node.js에 대한 관심이 있어서라기보다는, 아는 게 별로 없으니 귀동냥이라도 하면 좋지 않을까 해서 들어갔다. 저번 react 때는 설명을 듣고 나서 어려울 것처럼 느껴졌지만 그래도 흥미가 일었는데, 이번에는 그저 먼 얘기로만 들렸다. 백엔드는 아무래도 아닌 걸까?
  • BOJ 1964번 최소공배수를 구하는 데 유클리드 호제법...을 알게 되어서 매우 기뻤...다...... 후....^^....유클리드 호제법을 안 쓰고 식으로 구현해 풀려니 채점 중에 자꾸 시간 초과가 걸려버렸다.

 

                                 < 유클리드 호제법에 따라 두 자연수 a, b의 최대공약수를 구하는 방법 >
        a % b = r  →  b % (a % b) = r'  ->  (a % b) % {b % (a % b)} = r'''  ->  ...  ->  b가 0이 되면 그때의 a가 최소공약수
        이 말인즉슨, n+1번째 식으로 넘어갈 때마다 a에는 n번째 식의 b를, b에는 n번째 식 자체를 대입해야 한다는 것
        파이썬 while 문으로 b == 0 일 때까지 반복하면 딱이다

 

내일 할 일

  • 내일도 스터디에서 알고리즘 마라톤 문제를 6개 푼다. 스터디와 함께라면 두렵지 않아!
  • 쉬어가는 느낌으로 기본부터 다시 익히기 위해 <점프 투 파이썬> 1장을 본다.

'항해99 > 02_알고리즘(Day5~18)' 카테고리의 다른 글

항해02_알고리즘(Day11)  (0) 2021.06.18
항해02_알고리즘(Day9)  (0) 2021.06.16
항해02_알고리즘(Day8)  (0) 2021.06.15

오늘 한 일

  • 알고리즘 마라톤 문제를 4개 풀었다. 뒤로 갈수록 난이도가 높아져서 그런 건지 문제 푸는 속도가 점점 느려진다. 틀리는 횟수도 많아진다. 그래도 4개 채워서 너무 다행이다. 잘했다(셀프칭찬)!!!
  • 알고리즘 스터디를 모집하길래 급 지원했는데, 지원 안 했으면 두고두고두고두고두고 후회할 뻔했다. 항해99 와서 가장 잘한 일인 것 같다. 개인적인 이야기들도 했고 함께 머리를 맞대고 안 풀리는 문제에 대한 고민을 하나하나 나눠봤는데, 역시 사람 생각하는 건 다 거기서 거기...XD 이 스터디는 건강에 유익한 게 분명하다.
  • 스터디에서 알고리즘 마라톤 문제를 2개 더 풀었다! 물론 답안 코드를 보고 나서 '왜 이렇게 쉽게 풀려....?' 했지만, 아무튼 답을 찾아내기 위해서 우리끼리 고민해보고 얘기하는 시간이 유익했다. BOJ 4948번 베르트랑 공준 문제는 함께 푸는 데 3시간도 넘게 걸렸다. 이것도 답안지를 보고 푼 거지만 정말로 뿌듯하다!

내일 할 일 

  • 알고리즘 스터디에서 알고리즘 마라톤 문제 5번, 18번, 14번, 6번, 17번을 함께 푼다.
  • 시간이 남는다면, 문제를 1개만 혼자 더 풀어본다. (과연...?)

'항해99 > 02_알고리즘(Day5~18)' 카테고리의 다른 글

항해02_알고리즘(Day10)  (0) 2021.06.17
항해02_알고리즘(Day8)  (0) 2021.06.15
항해02_알고리즘(Day7)  (0) 2021.06.14

오늘 한 일

  • 주어진 알고리즘 문제를 앞에서부터 순서대로 7개 풀었다! 하루에 딱 평균치인 4개만이라도 풀자, 했었는데 생각보다 술술 풀려서 기분이 너무 좋았다. 나는 어쩔 수 없는 알알못이라고 생각했는데 그 정도는 아니었나...(❁´◡`❁) 희망이 보인다, 보여!
  • <Do it! 알고리즘 입문> 3장 '검색 알고리즘'을 봤다. 아직 모든 내용을 완벽하게 이해하지는 못하지만, 그래도 눈이 많이 적응한 것 같다. 내 집중력이 자주 고갈되고 예시 코드들을 따라 쳐 보느라 그랬지, 한 장을 다 읽는 데 시간 자체가 오래 걸리지는 않았다.
  • '알고리즘을 대하는 우리의 자세' 특강을 들었다. 코딩테스트 플랫폼 이용하기, 입문자 수준에서는 한 문제를 붙잡고 고민하는 것은 최대 20분까지만 잡기, 문제는 노트에 쓰면서 풀기, 다양하게 많이 풀기, 어차피 나중에는 혼자서 풀어 나가는 능력을 길러야 하니 지금 단계에서는 모르면 구글링이나 질문을 통해 도움 받기, 아직은 복잡도를 고민하기보다는 구현을 하는 데 더 신경쓰기.
  • BOJ 단계별 문제를 20개 풀었다. 하면 는다는 게 이런 건지, 어제보다 확실히 코드를 짜는 게 수월해졌다. 간단한 문제에서조차 버벅였던 어제였다면 생각하지 못했을 코드를 오늘은 보다 편하게 구성해 나갈 수 있었다.

내일 할 일

  • 오늘보다 난이도가 조금 더 있을 테니 걱정되기는 하는데, 알고리즘 문제는 4개 꼭 풀자.
  • <Do it! 알고리즘 입문> 4장 '스택과 큐'를 본다.
  • BOJ 단계별 문제 10개 풀기.
  • TIL 쓰기. 이제 이건 몸에 좀 익은 것 같다. 앞으로는 굳이 '내일 할 일'에 적지 않아도 되겠다.

'항해99 > 02_알고리즘(Day5~18)' 카테고리의 다른 글

항해02_알고리즘(Day9)  (0) 2021.06.16
항해02_알고리즘(Day7)  (0) 2021.06.14
항해02_알고리즘(Day6)  (0) 2021.06.13

오늘 한 일

  • <Do it! 알고리즘 입문> 2장 '기본 자료구조와 배열'을 봤다. 어제 작성한 TIL에서 너무나 높은 목표선을 설정해서 성취감이 참 떨어진다.. 하지만 배운 건 많다. 예를 들면 아래와 같은... 이 기본적인 걸 몰라서 코드 짤 때마다 얼마나 고생했던지.
    list('ABC')				# ['A', 'B', 'C']
    list({'name': 'Ann', 'age': '25'}) 	# ['name', 'age']
    if __name__ == '__main__':	# 해당 프로그램을 직접 시작한 경우에만 참, 
    				# 다른 스크립트 프로그램에서 임포트한 경우에는 거짓이 됨 
    				# 따라서 임포트한 경우 이 if문의 suite는 실행되지 않음​
  • 당장 알고리즘 문제를 풀 수 있어야 하는데 이 두꺼운 교재만 잡고 이론만 익히는 게 과연 효율적일까 싶어서 백준(BOJ)에서 단계별 문제를 21개 풀어봤다. 틀리면 맞을 때까지 풀었는데, 의외로 쉬운 문제들에서도 대목마다 고려해 줘야 하는 조건들이 있어 허무하게 틀리는 경우가 다반사였다. 예를 들면 input()으로 들어오는 값은 일단 무조건 문자열이다. 그래서 숫자로서의 입력값이 필요하다면 int()로 바꿔줘야 한다.
  • 그리고 오늘도 이렇게 TIL을 작성했다(뿌듯) 제출해야 하는 건 WIL이긴 했지만 일관되게 밀고 나가기(?) 위해서 어제까지의 TIL을 제출했다.

내일 할 일

  • 게더에서 제공되는 알고리즘 문제 4개를 푼다.
  • <Do it! 알고리즘 입문> 3장 '검색 알고리즘'을 공부한다. 이제부터는 목표를 설정하는 데 있어 욕심을 내지 말자^^제발...
  • BOJ 단계별 문제 10개만 더 풀자.

 

'항해99 > 02_알고리즘(Day5~18)' 카테고리의 다른 글

항해02_알고리즘(Day8)  (0) 2021.06.15
항해02_알고리즘(Day6)  (0) 2021.06.13
항해02_알고리즘(Day5)  (0) 2021.06.12

오늘 한 일

  • 문풀 위주인 5주차는 제외하고 알고리즘 강의를 4주차까지 들었다. 이해 여부와 상관없이 듣기로 했으니 목표는 완수한 셈이다. 나 같은 왕초보에게는 그저 어려울 따름이라서 개념에 익숙해지는 데 중점을 뒀다. 배열(array), 링크드 리스트(linked list), 재귀함수(recursion),  분할 정복(divide and conquer), 생성자(constructor), 스택(stack), 큐(queue), 해쉬(hash?hashing?), BFS(Breadth First Search), DFS(Depth First Search), 힙(Heap), 동적계획법(Dynamic Programming) 등등...
  • <Do it! 자료구조와 함께 배우는 알고리즘 입문 파이썬 편> 공부를 시작했고, 1장 '알고리즘 기초'까지 봤다. 반복되는 실습 코드, 부가 설명, 그림들을 보다 보니 알고리즘의 모양새(?)에 조금이나마 적응해 가는 것 같다. 기초적인 수준이나마 파이썬을 다루면서도 어느 대목에서 왜 사용하는 건지 어렴풋이만 알았던, 말 그대로 '기본' 개념들을 여기서 한 번씩 짚고 넘어가게 되어 무릎을 탁 치게 된 대목도 많았다. 그럴 때마다 그때 그때 구글링하는 것만으로는 채워지지 않던 갈증을 해소하는 기분이 들었다.

내일 할 일

  • 공식적으로는 휴식을 취하는 일요일이지만, 평소와 같이 오전 9시까지 일과를 시작할 준비를 마친다.
  • 오전 중에 <Do it! 알고리즘 입문> 2장 '기본 자료구조와 배열'을 마친다.
  • 점심 이후에 3장 '검색 알고리즘', 4장 '스택과 큐'를 공부한다.
  • TIL과 WIL을 적고, WIL 링크를 제출한다.
  • 시간과 마음의 여유가 허락한다면, 기초적인 알고리즘 문제를 1개 풀어본다.

'항해99 > 02_알고리즘(Day5~18)' 카테고리의 다른 글

항해02_알고리즘(Day8)  (0) 2021.06.15
항해02_알고리즘(Day7)  (0) 2021.06.14
항해02_알고리즘(Day5)  (0) 2021.06.12

오늘 한 일

  • 어제 제출한 미니 프로젝트 'MOVIE TALK(무비톡)'에 대한 그룹별, 개인별 회고의 시간을 가졌다. EC2 업로드에 문제가 생겨 제출 기한을 넘긴 게 가장 아쉬웠고, 그밖에는 좀 더 세련된 디자인을 고려하지 못한 점, 폰트 같은 것들의 통일성이 부족했던 점 등 주로 CSS 쪽이 부족하다고 평가했다. 처음이라 미비한 점은 있었다 해도 어쨌든 잠 줄여서 컴퓨터 앞에 잘 붙어 있으니 뭐라도 되는구나 싶었다. 밤새고 따가운 눈 문질러 가면서 해도 코딩은 즐거웠다.
  • TIL 작성의 중요성에 대해 알게 되었다. 그 덕에 지금 키보드를 두드리고 있다. 하마터면 새까맣게 잊어버릴 뻔했지 뭔가. TIL은 'Today I learned'의 줄임말이라는데, 사실 나는 초심자인 만큼 오늘 배운 점을 구체적으로 나열하지 않아도 'TIL' 이 한 마디면 충분할 것 같다. 매일매일 1분 1초가 나에겐 배움의 순간이라서, 말 그대로 오늘 하루는 언제나 'Today I learned(오늘 나는 배웠다)'로 요약할 수 있겠다.
  • 알고리즘 공부를 시작했다. 청년을 대상으로 하는 지원금 지급 업무를 할 때 내 또래 청년들이 너나 할 것 없이 왜 그리 다들 알고리즘이라는 것을 공부하는가 싶었는데 그것을 나도 오늘 접했다. 가뜩이나 수학 싫은데 수학적인 (느낌의) 개념을 코딩으로까지 표현하자니 숨이 턱턱 막힌다. 수업에서 예제로 나오는 것조차 나는 너무 버겁다. 알고리즘에서 내가 이해한 것들은 시간복잡도와 공간복잡도. 코딩에 있어 공간복잡도보다는 시간복잡도가 더 중요하고, 시간복잡도는 N으로 나타내는데 N 앞이나 뒤에 붙는 상수보다는 N 자체의 차수가 중요하다. 여러 경우에 따른 최악의 시간복잡도는 빅오표기법을 써서 O(N)과 같은 형태로 나타낸다.

내일 할 일

  • 무조건 알고리즘.. 문제를 척척 푸는 것까지는 바라지도 않는다. 이제 막 공부 시작한 지가 하루 이틀일 뿐이니까. 적어도 이런 식의 사고방식에 조금이라도 익숙해지고 싶다. 이해가 안 되더라도 강의는 꾸역꾸역 다 듣고 말겠다. 연습은 그 다음부터 해 나가면 될 일이다. 교보문고에서 주문한 알고리즘 책이나 얼른 왔으면 좋겠다. 제발 나 같은 초보를 배려해 주는 책을 알맞게 주문했기를...
  • 내일도 꼭 TIL을 적어보자.

'항해99 > 02_알고리즘(Day5~18)' 카테고리의 다른 글

항해02_알고리즘(Day8)  (0) 2021.06.15
항해02_알고리즘(Day7)  (0) 2021.06.14
항해02_알고리즘(Day6)  (0) 2021.06.13

+ Recent posts