Algorithm/스택&큐&덱&힙

[프로그래머스] PCCP 모의고사 1회 4번 운영체제

HANNI하니 2023. 12. 14. 17:45

사용 언어 - Python3

문제 - 운영체제

https://school.programmers.co.kr/learn/courses/15008/lessons/121686

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

정답

heapq 우선순위 큐

모든 부모들로 거슬러 올라가서 그 부모가 몇 번째 자식이었는지 확인

 

import heapq

heap = [] 우선순위 큐를 통해 프로그램 대기 list를 만들어준다.

 

0. time = 0 에서 시작

 

1. 호출시간과 우선순위를 기준으로 정렬한다.

빨리 호출된 순서대로, 호출시간이 같다면 우선순위가 높은 순으로 1차 정렬한다.

program.sort(key = lambda x: (x[1],x[0]))

 

2. 시간을 기준으로 push & pop

현재 시간 기준, 아직 호출되지 않았다면 그 값을 heapq에 push하고 program엔 pop해주며 빨리 처리해야하는 순서대로 heapq에 저장해준다.

더이상 현 시간에서는 대기시킬 프로그램이 없다면, 시간을 프로그램의 실행시간으로 늘려주면서 위 push, pop을 반복한다.

 

3. 우선순위대로 대기시간 계산

우선순위대로 저장된 heapq를 한개씩 pop하면서 한 프로그램씩 대기시간을 계산해준다.

대기시간 = 현재시간 - 호출시간

answer[프로그램점수] += 대기시간

한 프로그램 끝날 때마다 time += 실행시간

 

4. answer[0] = 프로그램 종료 시간 = 마지막 time

 

import heapq

def solution(program):
    answer = [0] * 11 
    heap = [] # 우선순위 큐. 프로그램 대기 list
    
    program.sort(key=lambda x: (x[1], x[0])) # 호출시간+우선순위 정렬
    time = 0

    while program or heap:
        # 아직 호출되지 않았다면 (=호출시간이 현재 시간보다 작다면)
        # 그 값을 heap에 push하고 pop해준다.
        while program and program[0][1] <= time:
            heapq.heappush(heap, program.pop(0))
            
        # 대기시킬 프로그램이 없는 경우,
        # 현재시간을 호출시간으로 바꾸기
        if program and not heap:
            time = program[0][1]
            heapq.heappush(heap, program.pop(0))
            
        # 우선순위대로 실행
        temp = heapq.heappop(heap)
        
        # 대기시간 = 현재시간-호출시간
        # 현재시간 += 실행시간
        answer[temp[0]] += (time - temp[1])
        time += temp[2]

    answer[0] = time
    return answer

 

 

 

(내 오답)

테스트케이스만 통과하는 풀이였다...

heapq 말고 q를 사용했음

from collections import deque
def solution(program):
    answer = [0]*11

    # 빨리 도착한 순으로 정렬
    program.sort(key = lambda x:x[1])

    # 늦게 도착했지만 점수가 더 낮다면 두개 자리 바꿔주기
    for i in range(1,len(program)-1):
        if program[i+1][0] < program[i][0]:
            program[i], program[i+1] = program[i+1], program[i]
            
    q = deque() # 끝시간 기록
    q.append(program[0][1] + program[0][2]) # 첫 프로그램의 끝시간 = 시작시간+실행시간
    
    for i in range(1,len(program)):
        # 두번째 프로그램의 시작시간 = 첫번째 프로그램의 끝시간
        # 2번째의 대기시간 = 두번째 프로그램의 시작시간 - 도착시간 
        now = q.popleft()
        # 두번째 프로그램의 끝시간 = 세번째 프로그램의 시작시간 = 첫번째 프로그램의 끝시간+실행시간
        q.append(now + program[i][2])

        # 프로그램 점수가 i인 프로그램들의 대기시간의 합
        for j in range(1,11): # 프로그램 점수 종류 최대 10개
            if j == program[i][0]: # 프로그램 점수에 해당한다면
                answer[j] += now - program[i][1] 
        
        # 끝나는 시간
        answer[0] = now + program[i][2]

    return answer

 

 

 

 

 

레퍼런스