[프로그래머스] 코딩 테스트 공부

2024. 9. 29. 22:14·PS/프로그래머스
반응형

문제

 

프로그래머스

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

programmers.co.kr

입력

alp:Int = 최초 알고력 
cop:Int = 최초 코딩력
problems:[[Int]] = problem의 배열   , 길이는 ≤ 6. 

problem = [alp_req, cop_req, alp_rwd, cop_rwd, cost]

alp_req는 문제를 푸는데 필요한 알고력입니다.
0 ≤ alp_req ≤ 150

cop_req는 문제를 푸는데 필요한 코딩력입니다.
0 ≤ cop_req ≤ 150

alp_rwd는 문제를 풀었을 때 증가하는 알고력입니다.
0 ≤ alp_rwd ≤ 30

cop_rwd는 문제를 풀었을 때 증가하는 코딩력입니다.
0 ≤ cop_rwd ≤ 30

cost는 문제를 푸는데 드는 시간입니다.
1 ≤ cost ≤ 100

결과

answer: Int = 모든 문제를 풀었을 때 최소 시간

해석

입력이 크게 길지 않고 알고력과 코딩력의 범위가 크지 않으므로 DP를 의심할 수 있다.

생각보다 DP 점화식은 문제에서 직관적으로 나왔다.

 

조건은 다음과 같다. 

 

1. 알고력과 코딩력을 키우는 방법은 크게 2가지이다.

  • 자습을 통해 알고력 또는 코딩력을 1 성장시킬수 있다, 비용 = 1시간 
  • 해당 문제를 푼다.  alp_rwd 와 cop_rwd 만큼의 알고력과 코딩력을 얻늗다, 비용 cost 시간

2. 해당 문제를 풀 때 alp_req와 cop_req을 보다 크거나 같아야 문제를 풀 수 있다.

 

이게 끝이다.

 

그러면 점화식은 다음과같다 . 

 

dp[alp][cop] = 현재 alp cop 상태일 때 최소 시간  

코드

import Foundation

func solution(_ alp:Int, _ cop:Int, _ problems:[[Int]]) -> Int {
    
    // 모든 문제를 풀어야함 
    
    var maxAlp: Int = 0 // 최대 Alp
    var maxCop: Int = 0 // 최대 Cop
    
    for problem in problems {
        maxAlp = max(maxAlp,problem[0])
        maxCop = max(maxCop,problem[1])
    }
    
    // 초기 상태 초기화
    var alp = min(maxAlp,alp) 
    var cop = min(maxCop,cop)
    
    var dp:[[Int]] = [[Int]](repeating:[Int](repeating:1000000, count: maxCop+2), count: maxAlp+2) 
    
    // dp[alp][cop] =  현재 alp와 cop 도달 시 최소 시간 
    
    // 알고력과 코딩력을 올리는 방법은 다음과 같다.
    // 1. 개인 공불르 통해 알고력 또는 코딩력을 1 증가 시킬 수 있다.
    // 2. 현재 문제를 풀어 reward로 얻을 수 있다. 
    
     dp[alp][cop] = 0 // 초기는 푼 문제와 걸린 시간이 없으므로 0 
    
    for i in alp...maxAlp {
        for j in cop...maxCop {
            dp[i+1][j] = min(dp[i+1][j], dp[i][j]+1) // 1시간 투자해서 알고력 높이기
            dp[i][j+1] = min(dp[i][j+1], dp[i][j]+1) // 1시간 투자해서 코딩력 높이기 
            
            // 현재 i,j의 알고력과 코딩력 일 때 문제 도전
            for problem in problems {
                let aReq = problem[0]
                let cReq = problem[1]
                let aRew = problem[2]
                let cRew = problem[3]
                let cost = problem[4]
                
                if i >= aReq && j >= cReq { // 모든 조건을 만족할 때 
                    let nextAlp = min(maxAlp,i + aRew)
                    let nextCop = min(maxCop,j + cRew)
                    
                    dp[nextAlp][nextCop] = min(dp[nextAlp][nextCop], dp[i][j] + cost)  
                }

            }
            
        }
    }
    

    return dp[maxAlp][maxCop]
}
반응형

'PS > 프로그래머스' 카테고리의 다른 글

[프로그래머스] 산 모양 타일링  (0) 2024.10.01
[프로그래머스] 미로 탈출 명령어  (1) 2024.09.30
[프로그래머스] 파괴되지 않은 건물  (0) 2024.09.29
[프로그래머스] 양과 늑대  (0) 2024.09.29
[프로그래머스] 광고 삽입  (0) 2024.09.28
'PS/프로그래머스' 카테고리의 다른 글
  • [프로그래머스] 산 모양 타일링
  • [프로그래머스] 미로 탈출 명령어
  • [프로그래머스] 파괴되지 않은 건물
  • [프로그래머스] 양과 늑대
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (339)
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (41)
        • swift (34)
        • python (6)
        • Kotlin (1)
      • iOS (134)
        • UIKit (37)
        • Combine (1)
        • SwiftUI (34)
        • Framework (7)
        • Swift Concurrency (22)
        • Tuist (6)
        • Setting (11)
        • Modularization (1)
        • Instruments (6)
      • PS (59)
        • 프로그래머스 (24)
        • 백준 (13)
        • LeetCode (19)
        • 알고리즘 (3)
      • Git (18)
        • 명령어 (4)
        • 이론 (2)
        • hooks (1)
        • config (2)
        • action (7)
      • Shell Script (2)
      • Linux (6)
        • 명령어 (5)
      • Spring (21)
        • 어노테이션 (6)
        • 튜토리얼 (14)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
      • AI (21)
        • 이론 (10)
        • MCP (1)
        • LangGraph (10)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    Tuist
    백준
    dfs
    protocol
    dp
    property
    lifecycle
    boostcamp
    AVFoundation
    UIKit
    프로그래머스
    concurrency
    GIT
    IOS
    Swift
    Spring
    dispatch
    SwiftUI
    투포인터
    CS
  • 최근 댓글

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[프로그래머스] 코딩 테스트 공부
상단으로

티스토리툴바