본문 바로가기

전체

(156)
[프로그래머스/Python] 기능개발(큐) 코딩테스트 연습 - 기능개발 프로그래머스 팀에서는 기능 개선 작업을 수행 중입니다. 각 기능은 진도가 100%일 때 서비스에 반영할 수 있습니다. 또, 각 기능의 개발속도는 모두 다르기 때문에 뒤에 있는 기능이 앞에 있는 programmers.co.kr def solution(progresses, speeds): answer = [] while progresses: #업데이트 for i in range(len(progresses)): progresses[i] += speeds[i] # 만약 첫번째꺼가 완료되면 완료된 애들 뺀다. if progresses[0] >= 100: cnt = 0 while progresses: if progresses[0] >= 100: progresses.pop(0) speed..
[프로그래머스/Python] 주식가격(스택) 코딩테스트 연습 - 주식가격 초 단위로 기록된 주식가격이 담긴 배열 prices가 매개변수로 주어질 때, 가격이 떨어지지 않은 기간은 몇 초인지를 return 하도록 solution 함수를 완성하세요. 제한사항 prices의 각 가격은 1 이상 10,00 programmers.co.kr 1. 이중 for문 현시점 이후의 가격을 다 살펴봐야 되므로 O(n^2)의 효율성을 보인다. def solution(prices): answer = [] for i in range(len(prices)): cnt = 0 for j in range(i+1, len(prices)): if prices[i] > prices[j]: cnt+=1 break else: cnt += 1 answer.append(cnt) return ..
[프로그래머스/Python] 프린터(큐) 코딩테스트 연습 - 프린터 일반적인 프린터는 인쇄 요청이 들어온 순서대로 인쇄합니다. 그렇기 때문에 중요한 문서가 나중에 인쇄될 수 있습니다. 이런 문제를 보완하기 위해 중요도가 높은 문서를 먼저 인쇄하는 프린 programmers.co.kr idx를 가지고 다니는 방식으로 작성했다. from collections import deque def solution(priorities, location): answer = 0 q = deque() for idx, paper in enumerate(priorities): q.append([paper, idx]) while q: cur = q.popleft() paper, idx = cur[0], cur[1] #우선순위 체크 flag = 1 for i in q: ..
[백준/Python] 백준 1697번 숨바꼭질 from collections import deque N, K = map(int, input().split()) visit = [False]*100001 cur = N time = 0 q = deque([[cur,time]]) while q: v = q.popleft() cur, time = v[0], v[1] if visit[cur] == False: if cur == K: print(time) break visit[cur] = True if cur + 1 = 0: q.append([cur-1, time+1]) if cur*2
[프로그래머스/Python] 수식 최대화 (반복/재귀) 코딩테스트 연습 - 수식 최대화 IT 벤처 회사를 운영하고 있는 라이언은 매년 사내 해커톤 대회를 개최하여 우승자에게 상금을 지급하고 있습니다. 이번 대회에서는 우승자에게 지급되는 상금을 이전 대회와는 다르게 다음과 programmers.co.kr 1. 반복문 풀이 from itertools import permutations def calc(prior, exp): for i in prior: while i in exp: idx = exp.index(i) exp[idx-1] = str(eval(exp[idx-1]+exp[idx]+exp[idx+1])) exp = exp[:idx] + exp[idx+2:] return exp[0] def solution(expression): # 1)우선순위 만들기 ope..
[프로그래머스/Python] 프렌즈4블록 코딩테스트 연습 - [1차] 프렌즈4블록 프렌즈4블록 블라인드 공채를 통과한 신입 사원 라이언은 신규 게임 개발 업무를 맡게 되었다. 이번에 출시할 게임 제목은 프렌즈4블록. 같은 모양의 카카오프렌즈 블록이 2×2 형태로 4개가 붙 programmers.co.kr def solution(m, n, board): answer = 0 dx = [1,1,0] dy = [1,0,1] def cnt_one(m,n,visit): cnt = 0 for i in range(m): for j in range(n): if visit[i][j] ==1: cnt +=1 return cnt while True: ''' 1) 사각형이 확인되면 그때의 좌표에 visit 1표시하기 2) visit이 1인 갯수 카운트해서 answe..
[프로그래머스/Python] 파일명 정렬 (문자열처리(반복/정규식) 코딩테스트 연습 - [3차] 파일명 정렬 파일명 정렬 세 차례의 코딩 테스트와 두 차례의 면접이라는 기나긴 블라인드 공채를 무사히 통과해 카카오에 입사한 무지는 파일 저장소 서버 관리를 맡게 되었다. 저장소 서버에는 프로그램 programmers.co.kr 1. 반복을 이용한 문자열 처리 def solution(files): answer = [] idx=0 for f in files: f = f.lower() H = "" for i in range(len(f)): if f[i].isdigit(): f = f[i:] break else: H += f[i] N = "" for i in range(len(f)): if f[i].isdigit()==False: f = f[i:] break else: N += f..
[프로그래머스/Python] 후보키(조합/비트연산) 코딩테스트 연습 - 후보키 [["100","ryan","music","2"],["200","apeach","math","2"],["300","tube","computer","3"],["400","con","computer","4"],["500","muzi","music","3"],["600","apeach","music","2"]] 2 programmers.co.kr 1. 조합 from itertools import combinations from collections import Counter def makeTuple(lists, tuples): # lists: 튜플로 변환할 리스트 # tuples: (몇개씩 묶어서 튜플로 만들 것인지) tmp = [] for i in tuples: tmp.append..