Combination Sum IV

2025. 2. 3. 14:26·PS/LeetCode
반응형

문제

https://leetcode.com/problems/combination-sum-iv/description/

입력

1 <= nums.length <= 200
1 <= nums[i] <= 1000
1 <= target <= 1000

결과

ans: Int = nums를 이용해 target을 만들 수 있는 중복조합의 수

해석

dfs와 memorization을 섞은 문제로 해석 된다.

target을 nums에 있는 수 만큼 내리는 top-down 방식으로 해결

target이 음수로 가면 가능성이 없으므로 0

target이 0이면 1을 리턴 

코드

class Solution {
    func combinationSum4(_ nums: [Int], _ target: Int) -> Int {
        var cache: [Int] = [Int](repeating: -1, count: target+1)
        cache[0] = 0
        return dfs(target, nums, &cache)
    }

    func dfs(_ target: Int, _ nums: [Int],_ cache: inout [Int]) -> Int {
        if target < 0 {
            return 0
        }
        
        if target == 0  {
            return 1 
        }

        if cache[target] != -1 {
            return cache[target]
        }

        var count: Int = 0

        for num in nums {
            count += dfs(target-num, nums, &cache)
        }
        cache[target] = count 
        return count
    }
}

 

반응형

'PS > LeetCode' 카테고리의 다른 글

House Robber II  (1) 2025.02.03
House Robber  (0) 2025.02.03
Word Break  (0) 2025.02.03
300. Longest Increasing Subsequence  (0) 2025.02.02
Climbing Stairs  (1) 2025.02.02
'PS/LeetCode' 카테고리의 다른 글
  • House Robber II
  • House Robber
  • Word Break
  • 300. Longest Increasing Subsequence
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (309) N
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (38)
        • swift (32)
        • python (5)
        • 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 (2) N
        • 이론 (2) N
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
Combination Sum IV
상단으로

티스토리툴바