[프로그래머스] 양과 늑대

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

문제

 

프로그래머스

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

programmers.co.kr

입력

info:[Int] = i번째 자리에 0이면 양, 1이면 늑대를 나타내는 정보 배열
2 ≤ info의 길이 ≤ 17

_ edges:[[Int]] = [[부모 노드, 자식노드],...] 로 간선에 연결된 부모자식 노드의 정보를 담고 있다. 
2 ≤ info의 길이 ≤ 17

출력

result = 담을 수 있는 최대 양의 마리 수

양 ≤ 늑대 마리 수가되면 지금까지 담은 양은 모두 잡아 먹힌다.

해석

1. 제약 조건은 간단하게 양의 수가 많을 때만 다음 늑대로 갈 수 있다.

2. 또한 들어오는 순서에 따라 이전에 방문할 수 없었던 지점을 다시 방문할 수 있기때문에 백트래킹을 생각할 수 있다.

코드

import Foundation

var answer = -1



func solution(_ info:[Int], _ edges:[[Int]]) -> Int {
    
    // 방문 여부를 나타내는 배열
    var visited: [Bool] = [Bool](repeating: false, count:info.count)
    

    func dfs(_ sheeps: Int,_ wolves: Int) {
        
        if sheeps > wolves {
           answer = max(answer, sheeps)
        }  else { // 양이 적가나 같으면 잡혀먹으니 return 
            return 
        }

        for edge in edges {
            
            let parent = edge[0]  
            let child = edge[1]
            
            // 백트래킹
            if visited[parent] && !visited[child] { // 부모가 방문하지 못했으면 child으로 방문하지 못함
                visited[child] = true
                if info[child] == 0 { // 양이면 다음 dfs에 sheeps+1 
                    dfs(sheeps+1,wolves)
                } else { // 늑대면 wolves+1
                    dfs(sheeps,wolves+1)
                }
                 visited[child] = false 
            }
            
        }
        

    }
    
    visited[0] = true 
    dfs(1,0)
    
    return answer
}
반응형

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

[프로그래머스] 코딩 테스트 공부  (0) 2024.09.29
[프로그래머스] 파괴되지 않은 건물  (0) 2024.09.29
[프로그래머스] 광고 삽입  (0) 2024.09.28
[프로그래머스] 합승 택시 요금  (0) 2024.09.27
[프로그래머스] 도넛과 막대 그래프  (0) 2024.09.23
'PS/프로그래머스' 카테고리의 다른 글
  • [프로그래머스] 코딩 테스트 공부
  • [프로그래머스] 파괴되지 않은 건물
  • [프로그래머스] 광고 삽입
  • [프로그래머스] 합승 택시 요금
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (304)
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (37)
        • swift (32)
        • python (4)
        • 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 (13)
        • 어노테이션 (1)
        • 튜토리얼 (11)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[프로그래머스] 양과 늑대
상단으로

티스토리툴바