2021 카카오 여름 인턴십 지원 및 서류 합격 2021년 4월, 카카오에서 여름 인턴십 채용을 진행하였습니다. 세 자리 수의 대규모 인턴 채용이라는 글을 많이 보게 되었고 친구가 카카오는 상반기에 인턴 하반기에 공채를 뽑는다고 하여 쓰게 되었습니다. 그 과정에서 카카오 인턴십에 합격하기 위해 블로그 후기를 찾아보았고, 그분들의 글로 인해 많은 도움을 얻을 수 있었던 것 같아서 다른 분들이 도움을 받았으면 좋겠다는 생각에 합격 후기를 적어보게 되었습니다. 채용 공고 카카오는 모든 지원자가 온라인 코딩 테스트를 볼 수 있게 하였고, 그 덕분인지 지원 접수를 할 때에는 자기소개서를 따로 작성하지 않았습니다. 여러 가지의 직무 중 저는 SERVER직무에 관심을 가지고 있었기 때문에 Server 분야에 지원서를 제출하였습니다. 그리고 지원을 한 다음날부터 친.. 2021. 6. 30.
[Programmers] Lv2. 게임 맵 최단거리 문제 바로가기 코딩테스트 연습 - 게임 맵 최단거리 [[1,0,1,1,1],[1,0,1,0,1],[1,0,1,1,1],[1,1,1,0,1],[0,0,0,0,1]] 11 [[1,0,1,1,1],[1,0,1,0,1],[1,0,1,1,1],[1,1,1,0,0],[0,0,0,0,1]] -1 programmers.co.kr 풀이 bfs를 사용해서 최단 거리를 구하고, visit을 확인하면서 갔던 경로는 가지 않도록 함 코드 from collections import deque d = [(-1, 0), (1, 0), (0, -1), (0, 1)] def solution(maps): n, m = len(maps) - 1, len(maps[0]) - 1 Q = deque([(0, 0, 1)]) visit = set([.. 2021. 6. 7.
[Programmers] Lv2. [1차] 뉴스 클러스터링 문제 바로가기 코딩테스트 연습 - [1차] 뉴스 클러스터링 뉴스 클러스터링 여러 언론사에서 쏟아지는 뉴스, 특히 속보성 뉴스를 보면 비슷비슷한 제목의 기사가 많아 정작 필요한 기사를 찾기가 어렵다. Daum 뉴스의 개발 업무를 맡게 된 신입사원 튜브 programmers.co.kr 풀이 str1과 str2를 모두 소문자로 변경하고, 두 글자씩 끊어서 영문자인 것만 리스트로 만든다. 새롭게 만든 str1과 str2 둘 다 아무것도 존재하지 않는다면 65536을 return 각각의 배열을 set으로 감싸서 같은 값을 제거하고 &(교집합)과 |(합집합)을 사용해 합집합, 교집합을 만든다. 집합을 만드는 과정에서 교집합은 각 str1, str2 배열에서 존재하는 개수의 최솟값의 합을 ans1 각 str1, st.. 2021. 5. 24.
[Programmers] Lv2. 문자열 압축 문제 바로가기 코딩테스트 연습 - 문자열 압축 데이터 처리 전문가가 되고 싶은 "어피치"는 문자열을 압축하는 방법에 대해 공부를 하고 있습니다. 최근에 대량의 데이터 처리를 위한 간단한 비손실 압축 방법에 대해 공부를 하고 있는데, 문 programmers.co.kr 풀이 최대 문자열 길이는 원래 문자열의 길이로 설정해두고, 1 ~ 문자열 전체 길이의 반까지 반복문을 돌린다. 기준 문자열(stand)과 개수(cnt)를 설정한 후 중복된 문자열을 찾는 반복문을 수행하는데 만약 기준 문자열과 같다면 개수를 추가해주고, 아니라면 이미 중복된 문자열이 존재할 때는 개수를 문자열로 바꿔서 추가해주고, 중복된 값이 없었다면 그대로 문자열만 추가해준다. 그 후 기준문자열과 개수를 초기화해주고, 반복문이 끝나면 ans.. 2021. 5. 24.
[Programmers] Lv2. 더 맵게 문제 바로가기 코딩테스트 연습 - 더 맵게 매운 것을 좋아하는 Leo는 모든 음식의 스코빌 지수를 K 이상으로 만들고 싶습니다. 모든 음식의 스코빌 지수를 K 이상으로 만들기 위해 Leo는 스코빌 지수가 가장 낮은 두 개의 음식을 아래와 같 programmers.co.kr 풀이 heapq를 사용하여 풀었다. 기존의 scoville배열을 heapify를 사용해 heap구조로 바꿔주고, scoville의 원소가 다 사라질 때까지 반복 만약 scoville의 원소가 다 사라져야 반복문이 종료된다면 모든 음식의 스코빌 지수가 K 이상이 될 수 없으므로 -1 그렇지 않다면, scoville의 첫 번째 원소가 K 이상이라면 답을 리턴한다. 이 과정에서 일단 첫 원소를 빼내고, 만약 두 번째 원소가 존재한다면 두 번.. 2021. 5. 24.
[Programmers] Lv2. 오픈채팅방 문제 바로가기 코딩테스트 연습 - 오픈채팅방 오픈채팅방 카카오톡 오픈채팅방에서는 친구가 아닌 사람들과 대화를 할 수 있는데, 본래 닉네임이 아닌 가상의 닉네임을 사용하여 채팅방에 들어갈 수 있다. 신입사원인 김크루는 카카오톡 오 programmers.co.kr 풀이 먼저, record를 돌면서 들어오거나 변경되는 유저의 아이디와 닉네임을 딕셔너리에 저장하는 과정을 거침 그러면 변경된 이름도 적용되어 있기 때문에, 다시 배열을 돌면서 Enter와 Leave에 해당하는 메시지를 남길 수 있음 코드 def solution(record): answer=[] nickname = {} for i in [i.split(' ') for i in record]: if i[0] != 'Leave': nickname[i[1.. 2021. 5. 24.
[Programmers ] Lv2. 타겟 넘버 문제 바로가기 코딩테스트 연습 - 타겟 넘버 n개의 음이 아닌 정수가 있습니다. 이 수를 적절히 더하거나 빼서 타겟 넘버를 만들려고 합니다. 예를 들어 [1, 1, 1, 1, 1]로 숫자 3을 만들려면 다음 다섯 방법을 쓸 수 있습니다. -1+1+1+1+1 = 3 +1-1+1+1+ programmers.co.kr 풀이 dfs함수를 통해 인덱스를 증가시키면서 2번의 재귀를 진행(-, +)하고, 만약 idx가 배열의 끝까지 진행되어서 원하는 값이 나왔다면 answer에 추가 코드 answer = 0 def dfs(numbers, target, idx, sum): global answer if idx == len(numbers): if sum == target: answer += 1 return dfs(num.. 2021. 5. 24.
[Programmers] Lv2. 기능개발 문제 바로가기 코딩테스트 연습 - 기능개발 프로그래머스 팀에서는 기능 개선 작업을 수행 중입니다. 각 기능은 진도가 100%일 때 서비스에 반영할 수 있습니다. 또, 각 기능의 개발속도는 모두 다르기 때문에 뒤에 있는 기능이 앞에 있는 programmers.co.kr 코드 def solution(progresses, speeds): answer = [] stack = [round((100 - progresses[0]) / speeds[0] + 0.5)] for i in range(1, len(progresses)): if stack[-1] >= round((100 - progresses[i]) / speeds[i] + 0.5): stack.append(stack[-1]) else: answer.appen.. 2021. 5. 20.
[Programmers] Lv2. 짝지어 제거하기 문제 바로가기 코딩테스트 연습 - 짝지어 제거하기 짝지어 제거하기는, 알파벳 소문자로 이루어진 문자열을 가지고 시작합니다. 먼저 문자열에서 같은 알파벳이 2개 붙어 있는 짝을 찾습니다. 그다음, 그 둘을 제거한 뒤, 앞뒤로 문자열을 이어 붙 programmers.co.kr 풀이 stack에 쌓고, stack에 요소가 존재하면 stack의 마지막요소와 비교해서 똑같을 경우만 stack에서 제거해줌 그리고 stack에 요소가 마지막에도 존재하면 0, 존재하지 않으면 1(가능)을 리턴 코드 def solution(s): stack = [] for i in s: if stack and i == stack[-1]: stack.pop() else: stack.append(i) return 0 if stack els.. 2021. 5. 20.
반응형