[프로그래머스] 합승 택시 요금

2024. 9. 27. 23:27·PS/프로그래머스
반응형

문제

 

프로그래머스

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

programmers.co.kr

입력

n:Int = 지점 개수  1<= n <= 200
s:Int = 출발 지점
a:Int = a 도착지점 
b:Int = b 독착지점
fares:[[Int]] = [[c,d,f]] 구조, c지점 <-> d지점 편도 택시 비용

 

결과

ans = a와 b가 s에서 출발해서 각자 도착지점까지 갔을 때 최소 택시 비용

해석

지점이 많지않고 몇개의 지점을 거치더라도 최소 비용으로 가기만하면 되기때문에

플로이드 와샬 알고리즘으로 접근해보자.

 

플로이드 와샬의 단계는 다음과 같다.

 

1. adj 인접배열 초기화

  • 자기 자신에게는 항상 최소이므로 0
  • 나머지는 INF로 초기화한다.

2. 모든 지점간 최소비용으로 adj 배열을 갱신한다. 이 때 dp를 이용하며 점화식은 다음과 같다.

adj[i][j] =  i에서 j까지 가는데 최소비용
adj[i][j] = min(adj[i][j], adj[i][k] + adj[k][j]) 현재 최소비용과  i->k , k->j를 거쳐갔을 때 비용 중 최소비용을 선택한다.

 

이후 모든 지점에 대해 최소비용을 계산하게 되면 이제 택시비용을 구할 수 있는 준비가 갖쳐졌다.

 

여기서 나는 a와 b가 어디서 해어져야 가장 싼 택시비용인지로 시점을 바꾸면 답이 바로 나왔다.

 

즉 헤어지는 지점을 찾아야햔다. 그러면 지점은 1~n개 이므로 그냥 돌아서 ((O(n)))이면 충분할 것 같다.

 

그러면 그 지점을 찾는 점화식은 다음과 같다.

 

ans = min(ans, adj[s][i] + adj[i][a] + adj[i][b])

adj[s][i] = 헤어지는 지점까지 같이 타고간 비용
adj[i][a] = 헤어진 지점부터 도착지점 a까지 따로 타고간 비용
adj[i][b] = 헤어진 지점부터 도착지점 b까지 따로 타고간 비용

코드

import Foundation

let MAX = 1000000

var adj: [[Int]] = Array(repeating: 
                         Array(repeating:MAX, count: 201),  
                           count:201)


func solution(_ n:Int, _ s:Int, _ a:Int, _ b:Int, _ fares:[[Int]]) -> Int {
    // a = a 도착지점 
    // b = b 도착지점
    // s = 출발지점
    
    for i in 1...n {
        adj[i][i] = 0
    }

    for fare in fares {
        let c = fare[0]
        let d = fare[1]
        let f = fare[2]
        adj[c][d] = f 
        adj[d][c] = f
    }
    
    for k in 1...n {
        for i in 1...n {
            for j in 1...n {
                if adj[i][j] > adj[i][k] + adj[k][j] {
                    adj[i][j] = adj[i][k] + adj[k][j]
                }
            }
        }
    }   
    
    var ans: Int = Int.max
    
    for mid in 1...n {
        ans = min(ans, adj[s][mid] + adj[mid][a] + adj[mid][b])
    }
    
    return ans
}

 

반응형

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

[프로그래머스] 양과 늑대  (0) 2024.09.29
[프로그래머스] 광고 삽입  (0) 2024.09.28
[프로그래머스] 도넛과 막대 그래프  (0) 2024.09.23
[프로그래머스] 택배 배달과 수거하기  (0) 2024.09.22
[프로그래머스] 이모티콘 할인행사  (2) 2024.09.21
'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)
      • AI (0)
        • 이론 (0)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[프로그래머스] 합승 택시 요금
상단으로

티스토리툴바