[Algorithm] 백준 - 27277번 장기자랑 (Swift)

2024. 3. 22. 17:08· → Problems
목차
  1. 문제
  2. 문제 풀이

문제

27277번: 장기자랑

실력이 $4, 2, 3, 5, 1, 6$인 순서로 공연하면, 각 병사가 발휘할 수 있는 실력은 순서대로 $4, 0, 1, 2, 0, 5$이므로 실력의 합이 $12$인 채로 공연을 끝마칠 수 있다.

www.acmicpc.net

 
 

문제 풀이

max(0, 현재값-이전값)에서 최대의 효과를 발휘하려면 (현재값-이전값) > 0이고, 그것이 최대로 클 때 최대 효율을 발휘할 수 있다. 예를 들면 [1,2,3,4]가 있다면 [4,1], [3,2]을 짝지어야 최종합 4로 최댓값을 만들 수 있다. 만약 배열이 홀수일 경우 큰 수와 작은 수를 짝지은 후 남은 값을 맨 마지막에 추가해 주면 된다.

import Foundation

var n = Int(readLine()!)!
var skills = readLine()!.split(separator: " ").map{ Int(String($0))! }

func solution(_ n: Int, _ skills: [Int]) -> Int {
    let skills = skills.sorted()
    var answer = [Int]()
    var maxSkill = 0
        
    for i in 0..<n/2 {
        answer.append(skills[n-i-1])
        answer.append(skills[i])
    }
    
    if n % 2 == 1 {
        answer.append(skills[n/2])
    }
        
    for i in 1..<answer.count {
        maxSkill += max(0, answer[i] - answer[i-1])
    }
    
    maxSkill += answer[0]
    
    return maxSkill
}

print(solution(n, skills))

'→ Problems' 카테고리의 다른 글

[Algorithm] 프로그래머스 - 배달 (Swift) (플로이드 워셜, DFS)  (0) 2024.03.28
[Algorithm] 프로그래머스 - 하노이의 탑 (Swift)  (1) 2024.03.27
[Algorithm] 프로그래머스 - 합승 택시 요금 (Swift)  (0) 2024.03.20
[Algorithm] 프로그래머스 - 요격 시스템 (Swift)  (0) 2024.03.20
[Algorithm] 프로그래머스 - 길 찾기 게임 (Swift)  (0) 2024.03.19
  1. 문제
  2. 문제 풀이
'→ Problems' 카테고리의 다른 글
  • [Algorithm] 프로그래머스 - 배달 (Swift) (플로이드 워셜, DFS)
  • [Algorithm] 프로그래머스 - 하노이의 탑 (Swift)
  • [Algorithm] 프로그래머스 - 합승 택시 요금 (Swift)
  • [Algorithm] 프로그래머스 - 요격 시스템 (Swift)
Swift librarian
Swift librarian
Swift librarian
Swift Library
Swift librarian
전체
오늘
어제
  • 분류 전체보기 (231)
    • 📺 Programming (5)
    • → Architecture (2)
    • → Design Pattern (0)
    • → Computer Science (15)
    • ⚙️ Algorithm (0)
    • → 알고리즘 관련 (22)
    • → Problems (104)
    • 🚀 Project (0)
    • → 알쏭달쏭 (0)
    • → Shook (2)
    • → Solver (8)
    • → Taster (7)
    • → Outline (4)
    • → Pointer (2)
    • → Guesser (3)
    • 🦜 Swift (2)
    • → Swift Archive (12)
    • → Swift Study (12)
    • → Xcode (6)
    • 🧰 Framework (0)
    • → Foundation (1)
    • → UIKit (2)
    • → SwiftUI (3)
    • → CoreData (2)
    • → MapKit (1)
    • → CoreHaptic (1)
    • → User Notification (1)
    • → StoreKit (2)
    • 🏛️ Library (0)
    • → TCA (0)
    • 🐈‍⬛ Git (8)
    • → Git의 원리 (2)
    • → Git 심화 (1)
    • 📦 Other (1)
    • 👦🏻 Log (0)

최근 글

hELLO · Designed By 정상우.v4.2.2
Swift librarian
[Algorithm] 백준 - 27277번 장기자랑 (Swift)
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.