전체 글

전체 글

    [프로그래머스] 키패드 누르기 /파이썬 /Python /2020 카카오 인턴십

    💡solutions ) ✅ 세 가지 경우로 나눈다 - #left 왼손가락을 움직이는 경우(1,4,7) - #right 오른손가락을 움직이는 경우(3,6,9) - #middle 가운데 번호인 경우에는 -> 각 두 손가락의 위치와 움직여야 하는 숫자 간의 거리를 구해서 값 비교하기(distance) ✅ 거리는 좌표를 활용해 맨하탄 거리로 구한다 -> distance 함수 구현 ✅ d_r(오른 손가락과의 거리)가 d_l(왼 손가락과의 거리)보다 크면 L 붙이기 (왼 손가락 이동), 그 반대도 성립 ✅ 만약 거리 차이가 같으면 왼손잡이인지 오른손잡이인지 판별 후 answer에 이동한 손가락 더하기 ✅ 테스트 케이스 8번 15번에서 자꾸 오류가 나서 덕봇기와 함께 살펴보니 처음 초기값 tmp_r과 tmp_l를 0..

    비금융정보를 활용한 신용평가 시스템

    금융권에서는 비금융정보를 활용한 대안신용평가체계가 활발히 구축되고 있다. 신용평가에서 비금융정보를 활용함으로써 기존 금융거래 이력이 부족한 사회초년생들과 소득을 증빙하기 어려운 은퇴자들의 대출이 가능할 것으로 예상된다. 🎫 비금융정보를 활용한 신용평가 => 은행에서 대출을 받으려면 본인의 소득 증빙, 대출 이력, 자산 증빙 등 금융정보만을 대상으로 심사받았던 것과 달리 최근에는 휴대전화 요금이나 건강보험료 납부 내역 등을 참고하여 신용평가가 이뤄지고 있다. 🎫 현재 진행 상황은? => 네이버 금융자회사인 네이버파이낸셜은 자사만의 대안신용평가시스템을 구축했다. 기존 신용평가회사가 보유한 금융데이터에 네이버가 인공지능, 머신러닝, 빅데이터 기술로 분석한 스마트스토어 데이터를 더해 만든 평가시스템이다. 이 시..

    [프로그래머스] 튜플/ 파이썬/ Python/ 2019 카카오 개발자 겨울 인턴십

    💡solutions ) ✅ ',{'를 기준으로 집합별로 끊어준다(split) ✅ 문자 길이를 기준으로 정렬한다(sort) ✅ 집합에 들어 있는 원소들을 꺼내어 숫자인 경우에는 answer에 있는 지 확인 후 없으면 담아준다. ✅ 다른 사람 풀이를 찾아보다 보니, 정규 표현식을 활용한 경우가 있었다. 파이썬의 re(regular expression) 모듈을 사용, findall() 메서드를 통해 문자열을 검색할 수 있다. 이 문제에서는 i를 바로 re.findall("\d+", i)로 표현해 숫자값들만 찾아서 리스트에 담아줄 수 있다. 🎫code ) def solution(s): answer = [] a = s.split(',{') a.sort(key = len) tmp = '' for i in a: fo..

    [프로그래머스] 문자열 압축/ 파이썬/ Python/ 2020 KAKAO BLIND RECRUITMENT/ 카카오 블라인드 채용

    💡solutions ) ✅ slicing으로 문자열을 몇개씩 끊을 것인지 정해서 반복문으로 처리, 이때 범위는 len(s)//2+2인데, 전체 문자열의 범위 절반까지가 최대 압축 길이기 때문에 문자열 절반까지로 끊는다. 이때 문자열이 1인 경우를 고려하지 않아서 처음에는 len(s)//2 +1로 했다가 테스트 케이스 하나가 오류 났었다. 문자열 1인 경우를 포함하기 위해 len(s)//2+2로 수정했다. ✅ tmp는 기준 단위로 끊은 문자열을 비교를 위해 담아둔다. ✅ 그 다음 문자열부터 다시 반복문을 돌며 같은 단위의 문자열이 있는지 확인한 후 같으면 cnt+1, 다르면 tmp가 몇번 반복해서 나왔는지 cnt를 앞에 붙여서 res에 담아준다.(이때 cnt가 1이면 res에 tmp만 담기) ✅ 결국 답이..

    [프로그래머스] 프린터 /파이썬 / Python / deque

    💡solutions ) ✅ 스택에서 pop(0) 하는 것보다(시간복잡도 O(N)) deque 자료형으로 popleft()하는 게 훨씬 효율적이다(시간복잡도O(1)) ✅ 밸류 값과 인덱스 값을 함께 사용하므로 enumerate 함수 사용 ✅ item 보다 max 이 크다면 다시 배열에 담아주고, 그렇지 않은 경우 answer+1 ✅ item의 인덱스가 location이랑 동일하다면 반복문 종료 -> answer 반환 ✅ 다른 사람의 풀이를 확인해 보니 파이썬 내장함수 중 any를 사용해서 while문 안의 조건문을 짠 코드도 있었다. if any( item[0] item[0]: array.append(item) else: answer += 1 if item[1] == location: break retur..

    [프로그래머스] 더 맵게 /파이썬 /Python / heapq

    💡solutions ) ✅ 처음에 heapq 자료구조 사용하지 않고 sort를 했다가 런타임 에러가 떴었다. 다른 분들은 처음부터 heapq를 사용하시길 바란다. ✅ 참고로 heapq는 heappush, heappop을 할 때 자동으로 정렬을 해주어 효율성이 높아진다고 한다. 🎫code ) import heapq def solution(scoville, K): items = [] for i in scoville: heapq.heappush(items, i) cnt = 0 while items[0] < K: try: heapq.heappush(items, heapq.heappop(items)+(heapq.heappop(items)*2)) except: return -1 cnt += 1 return cnt ..

    [프로그래머스] 124 나라의 숫자 /파이썬 /Python

    💡solutions ) ✅ 삼진법 -> 3으로 나눈 후 나머지를 num 리스트의 인덱스로 사용한다. ✅ 나머지가 0이면 num[0] = 1, 나머지 1이면 num[1] = 2, 나머지 2이면 num[2] = 4 🎫code ) def solution(n): num = ['1','2','4'] answer = "" while n > 0: n -= 1 answer = num[n % 3] + answer n //= 3 return answer 📌 description ) 문제출처 : programmers.co.kr/learn/courses/30/lessons/12899?language=python3 코딩테스트 연습 - 124 나라의 숫자 124 나라가 있습니다. 124 나라에서는 10진법이 아닌 다음과 같은 자..

    [프로그래머스] 시저 암호 /파이썬 /Python

    💡solutions ) ✅ 대소문자 구분해준 후 ord 메소드로 아스키 코드 변환 -> 이때 마지막 Z를 벗어나는 경우는 26을 빼주어 다시 A로 돌아가 계산 -> chr 메소드로 다시 문자열 변환 ✅ 아래 아스키 코드표 참고 🎫code ) def solution(s, n): answer = '' s = list(s) for a in s: if a != ' ': num = ord(a) + n if 65 122: # 마지막 z 넘가는 경우 num = num - 26 res = chr(num) answer += res else: # 공백 문자 처리 answer += a return answer 📌 description ) 문제출처 : programmers.co.kr/learn/courses/30/lesson..