[Algorithm] 백준 - 15824번 너 봄에는 캡사이신이 맛있단다 (Swift)

2024. 7. 7. 22:39· → Problems
목차
  1. 문제 소개
  2. 해결 과정
  3. 첫 번째 풀이 (50점)
  4. 정답 (250점)

문제 소개

해결 과정

첫 번째 풀이 (50점)

최대, 최솟값을 결정하고 나머지는 2^n으로 최대 최소일 경우 몇 번의 경우가 있는지를 구하면 되는 문제였다. 문제는 모듈러 연산... 처음에 2의 n제곱을 구하는데 모듈러 연산을 안 해줘서 자꾸 런타임 오류가 났었다. 

let fileIO = FileIO()

let n = fileIO.readInt()
let mod = 1_000_000_007

var answer = 0
var sco = [Int]()

for _ in 0..<n {
    let s = fileIO.readInt()
    sco.append(s)
}

sco.sort()

var pow2 = [Int](repeating: 1, count: n)
for i in 1..<n {
    pow2[i] = (pow2[i - 1] * 2) % mod
}

for i in 0..<n {
    for j in (i + 1)..<n {
        let scobil = sco[j] - sco[i]
        answer = (answer + scobil * pow2[j - i - 1] % mod) % mod
    }
}

print(answer)

하지만 이 풀이의 문제점은 2중 반복문이 들어가기 때문에 n = 300,000 일때 90000,000,000의 연산을 하기 때문에 시간초과가 발생한다.

정답 (250점)

생각해보면 단순했다. 굳이 최대 최소를 결정할 필요 없이 하나의 메뉴가 있다면 최대일 경우는 그것보다 전에 있는 메뉴 개수의 2^n이고, 그 메뉴가 최소일 경우는 그 이후에 있는 메뉴 개수의 2^n이다.

let n = Int(readLine()!)!

let mod = 1_000_000_007
var answer = 0

var menus = readLine()!.components(separatedBy: " ").map { Int($0)! }
menus.sort()

var pow2 = [Int](repeating: 1, count: 30_0001)
for i in 1..<300000 {
    pow2[i] = (pow2[i - 1] * 2) % mod
}

for i in 0..<n {
    let menu = menus[i] % mod
    var cases = (pow2[i] - pow2[n - i - 1]) % mod
    if cases < 0 { cases += mod }
    answer = (answer + menu * cases % mod) % mod
}

print(answer)

입출력 라이브러리를 쓰지 않으면 564ms, 쓰면 80ms 나오는 듯하다.

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

[Algorithm] 백준 - 11689번 GCD(n, k) = 1  (0) 2024.07.09
[Algorithm] 백준 - 16565번 포커 (Swift)  (0) 2024.07.08
[Algorithm] 백준 - 1334번 철로 (Swift)  (0) 2024.07.07
[Algorithm] 백준 - 1019번 책 페이지 (Swift)  (0) 2024.07.06
[Algorithm] 프로그래머스 - 도넛과 막대 그래프 (Swift)  (0) 2024.07.05
  1. 문제 소개
  2. 해결 과정
  3. 첫 번째 풀이 (50점)
  4. 정답 (250점)
'→ Problems' 카테고리의 다른 글
  • [Algorithm] 백준 - 11689번 GCD(n, k) = 1
  • [Algorithm] 백준 - 16565번 포커 (Swift)
  • [Algorithm] 백준 - 1334번 철로 (Swift)
  • [Algorithm] 백준 - 1019번 책 페이지 (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] 백준 - 15824번 너 봄에는 캡사이신이 맛있단다 (Swift)
상단으로

티스토리툴바

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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