광물캐기

2023. 8. 7. 03:12·Coding Test/programmers
728x90

https://school.programmers.co.kr/learn/courses/30/lessons/172927

 

프로그래머스

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

programmers.co.kr

 

분석

  • 사용할 수 있는 곡괭이중 아무거나 하나를 선택해 광물을 캡니다.
  • 한 번 사용하기 시작한 곡괭이는 사용할 수 없을 때까지 사용합니다.
  • 광물은 주어진 순서대로만 캘 수 있습니다.
  • 광산에 있는 모든 광물을 캐거나, 더 사용할 곡괭이가 없을 때까지 광물을 캡니다.
picks [1, 3, 2] ([dia, iron, stone]과 같은 구조)
minerals  ["diamond", "diamond", "diamond", "iron", "iron", "diamond", "iron", "stone"]

minerals diamond diamond diamond iron iron diamond iron stone
picks dia dia dia dia dia iron iron iron
picks 사용 1 2 3 4 5 1 2 3
피로도 1 1 1 1 1 5 1 1
  1. 광물 5개씩 끊어 리스트 생성 : 곡괭이 하나당 5개의 광물을 캐기 때문
  2. 5광물 리스트를 sort : 다이아, 철, 돌 순으로 정렬하여 피로도를 낮게 캐기 위해
  3. 5광물 리스트를 돌면서 곡괭이 사용
    1. 곡괭이 사용 잔여 횟수 감소
    2. 피로도 추가
picks [0, 1, 1] ([dia, iron, stone]과 같은 구조)
minerals  ["diamond", "diamond", "diamond", "diamond", "diamond", "iron", "iron", "iron", "iron", "iron", "diamond"]

광물 5개씩 끊은 리스트 : [[5, 0, 0], [0, 5, 0], [0, 0, 0]]

곡괭이 선택

picks, j, picks[j]
[0, 1, 1] 0 0 다이아 곡괭이 없음
[0, 1, 1] 1 1 철 곡괭이로 광물 캐기
[0, 0, 1] 0 0 다이아 곡괭이 없음 
[0, 0, 1] 1 0 철 곡괭이 없음 
[0, 0, 1] 2 1 돌 곡괭이로 광물 캐기
[0, 0, 0] 0 0 다이아 곡괭이 없음
[0, 0, 0] 1 0 철 곡괭이 없음 
[0, 0, 0] 2 0 돌 곡괭이로 광물 캐기

 

풀이

def solution(picks, minerals):
    answer = 0

    if len(minerals)>sum(picks)*5:
        minerals=minerals[:sum(picks)*5]

    # 광물 5개씩 끊은 리스트
    mlist=[[0,0,0] for _ in range((len(minerals))//5+1)]
    for i in range(len(minerals)):
        if minerals[i]=='diamond':
            mlist[i//5][0]+=1
        elif minerals[i]=='iron':
            mlist[i//5][1]+=1
        elif minerals[i]=='stone':
            mlist[i//5][2]+=1

    mlist.sort(key=lambda x:(-x[0], -x[1], -x[2]))
    
    for x in mlist:
        dia,iron,stone = x
        for j in range(len(picks)):
            if picks[j]>0 and j==0: # 다이아몬드 곡괭이
                picks[j]-=1
                answer+=dia+iron+stone
                break
            elif picks[j]>0 and j==1: # 철 곡괭이
                picks[j]-=1
                answer+=dia*5+iron+stone
                break
            elif picks[j]>0 and j==2: # 돌 곡괭이
                picks[j]-=1
                answer+=dia*25+iron*5+stone
                break
    return answer

 

 

728x90
저작자표시 비영리 변경금지 (새창열림)
'Coding Test/programmers' 카테고리의 다른 글
  • 풍선 터트리기 (스택, 최솟값 비교, memoization)
  • 괄호 회전하기 (스택)
  • 미로탈출 (BFS)
  • 혼자 놀기의 달인 (리스트 인덱스, 값 union)
Karla Ko
Karla Ko
𝘾𝙤𝙣𝙩𝙞𝙣𝙪𝙤𝙪𝙨𝙡𝙮 𝙄𝙢𝙥𝙧𝙤𝙫𝙞𝙣𝙜, 𝘾𝙤𝙣𝙨𝙩𝙖𝙣𝙩𝙡𝙮 𝘿𝙚𝙫𝙚𝙡𝙤𝙥𝙞𝙣𝙜 𝙔𝙚𝙨!
    250x250
  • Karla Ko
    karlaLog
    Karla Ko
  • 전체
    오늘
    어제
    • Total (467)
      • Spring (19)
      • JPA (4)
      • Cloud & Architecture (15)
        • Kubernetes (5)
        • Docker (3)
        • MSA (2)
        • GCP (1)
        • AWS (4)
      • Devops (1)
      • Message Queue (4)
        • Kafka (2)
        • RabbitMQ (2)
      • Git (4)
      • DB (4)
      • Java (9)
      • Python (4)
      • CS (11)
        • OS (8)
        • Network (2)
        • Algorithm (1)
      • Coding Test (392)
        • programmers (156)
        • Graph (43)
        • DP (37)
        • Search (31)
        • Tree (13)
        • Data Structure (26)
        • Combination (12)
        • Implement (18)
        • Geedy (23)
        • Sort (7)
        • Math (21)
        • geometry (2)
  • 블로그 메뉴

    • 홈
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    자료구조
    LIS
    힙
    최단거리
    트리
    정렬
    이분탐색
    파이썬
    그래프
    플로이드워셜
    재귀
    동적계획법
    덱
    큐
    알고리즘
    최대공약수
    프로그래머스
    월간코드챌린지
    백준
    BFS
    구현
    Algorithm
    조합
    DP
    구간합
    DFS
    다익스트라
    스택
    최소신장트리
    그리디
  • hELLO· Designed By정상우.v4.10.3
Karla Ko
광물캐기
상단으로

티스토리툴바