[프로그래머스] 산 모양 타일링

2024. 10. 1. 00:31·PS/프로그래머스
반응형

문제

 

프로그래머스

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

programmers.co.kr

 

입력

n:Int = 윗변의 길이
tops:[Int] = 정삼각형의 위쪽에 정삼각형을 붙이는 여부

tops[i] = 0  없는 경우
tops[i] = 1  위에 삼각형이 있는 경우

결과

ans: Int = 만들 수 있는 경우의 수를 10007로 나눈 결과

놓을 수 있는 경우의 수

해석

 

보자마자 dp를 의심할 수 있다. 왜냐하면 이전 삼각형 상태로 다음 상황이 결정되기 때문에 부분 문제를 풀어야되는 dp카테고리다.

 

경우의 수를 생가가해보지.

 

 

1. 현재 i-1에 2번이 놓여있을 때

  • i에 1,3,4(위에 공간이 있을 때) 놓을 수 있음 

2. 현재 i-1에 3번이 놓여있을 때

  • i에 1,4(위에 공간이 있을 때) 놓을 수 있음

즉, 현재 i 번째에 위에 삼각형을 놓을 수 있는, 즉 tops[i] = 1 라면 4번이 가능하고 그렇지 않으면  그 나머지만 가능하다.

 

현재 i에 2번 사각형을 놓을려 할 때  경우의 수

1. tops[i] = 1 
- dp[i-1]에 2번을 놓았을 때 *3 + dp[i-1]에 3번을 놓았을 때 * 2 

2. tops[i] = 0  
- 4번 만 싹 빼면
-  dp[i-1]에 2번을 놓았을 때 *2 + dp[i-1]에 3번을 놓았을 때 * 1

 

그렇다면 i번째에 3번을 놓을려면 ?? 따로 앞에서 제약받는게 없다 이전 상황의 경우의 수를 그대로 이어 받는다.

dp[i+1] = dp[i]에 2번을 놓았을 때 + dp[i]에 3번을 놓았을 때 

 

정리하면 

 

dp[i][0] = i 번째 윗변에 왼쪽 사다리꼴을 쓸 경우 , dp[i][1] = i 번째 오른쪽 사다리꼴 쓸경우

1. 왼쪽 고려
a. 위에 놓을 수 있을 때
dp[i+1][0] = dp[i][0]*3 + dp[i][1]*2

b. 놓을 수 없을 때

2. 오른쪽 고려
dp[i+1][1] = (dp[i][0] + dp[i][1])

코드

import Foundation

func solution(_ n:Int, _ tops:[Int]) -> Int {
    
    let DIV: Int = 10007
    
    var dp: [[Int]] = [[Int]](repeating:[0,0],count:n+1) // dp[i][0] = i 번째 윗변에 왼쪽 사다리꼴을 쓸 경우 , dp[i][1] = i 번째 오른쪽 사다리꼴 쓸경우 
    
    dp[0][0] = 1 // 
    
    for i in 0..<n {
        
        if tops[i] == 1 { // 세로형을 사용할 수 있음 
            
            //i+1에 왼쪽꺼를 놓을려면 , i번째는 오른쪽 거를 놓으면 안됨
            
            // dp[i][0] = (오른쪽 꺼 사용불가)  왼쪽형 ,세로형 , 그냥 정삼각형 = 3 
            
            // dp[i][1] = (왼쪽꺼 사용 불가)  정삼각형, 세로 = 2
        
            dp[i+1][0] = dp[i][0]*3 + dp[i][1]*2 
        }
        
        else { // 세로형 사용 불가 , 위와 똑같지만 세로형 만 빼야됨
            
            dp[i+1][0] = dp[i][0]*2 + dp[i][1]*1
        }
        
         //i+1에 오른쪽 껄 놓을 때는 i번째가 왼쪽이든 오른쪽이든 상관 없음
        dp[i+1][1] = (dp[i][0] + dp[i][1]) % DIV
        
        dp[i+1][0] %= DIV 
        
       
        
        
    }

    
    return (dp[n][1] + dp[n][0]) % DIV
}
반응형

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

[프로그래머스] 택배상자  (2) 2024.10.02
[프로그래머스] n + 1 카드게임  (0) 2024.10.01
[프로그래머스] 미로 탈출 명령어  (1) 2024.09.30
[프로그래머스] 코딩 테스트 공부  (0) 2024.09.29
[프로그래머스] 파괴되지 않은 건물  (0) 2024.09.29
'PS/프로그래머스' 카테고리의 다른 글
  • [프로그래머스] 택배상자
  • [프로그래머스] n + 1 카드게임
  • [프로그래머스] 미로 탈출 명령어
  • [프로그래머스] 코딩 테스트 공부
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (308) N
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (38) N
        • swift (32)
        • python (5) N
        • Kotlin (1)
      • iOS (132)
        • UIKit (37)
        • Combine (1)
        • SwiftUI (32)
        • 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 (15) N
        • 어노테이션 (3) N
        • 튜토리얼 (11)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
      • AI (1) N
        • 이론 (1) N
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[프로그래머스] 산 모양 타일링
상단으로

티스토리툴바