[백준] 3273 두 수의 합

2024. 10. 14. 22:01·PS/백준
반응형

문제

https://www.acmicpc.net/problem/3273

 

입력

n = 수열의 길이
arr = 수열
x = 만들어야하는 목표

1 <= n <= 100000
1 <= x <= 2000000
1 <= arr[i] <= 1000000

결과

ans: Int = ai + aj로 x를 만들 수 있는 쌍의 수

해석

1. 각각의 숫자의 개수를 카운팅한다.

2. x = 5 , arr = [2,2,3,3] 일 때 만들 수 있는 경우의 수는  (2,3) ,(3,2) 2개다  하지만 두개를 같게 보기때문에 1개이다.

다시 말하면 식은 다음과 같다 

 

 (ans =  \sum_{i = a_{1}}^{a_{n}} \frac{count(i) + count(j)}{2})

 

나누기 2를 하는 이유는 (2,3) = (3,2)므로 

 

 

코드

import Foundation

let n = Int(readLine()!)!

let arr = readLine()!.split{$0 == " "}.map{Int($0)!}.sorted()
let x = Int(readLine()!)!

var ans: Int = 0

var left: Int = 0
var right: Int = n-1

let max = 1000000

var count: [Int] = [Int](repeating: 0, count: max+1)

for num in arr {
    count[num] += 1
}

for n1 in arr {
    if n1 >= x { // x를 넘거나 같으면 쌍을 만들 수 없음
        break
    }
    
    let n2 = x-n1
    
    if n1 > max || n2 > max { // 범위를 벗어남
        continue
    }
    
    
    ans += (count[n1] * count[n2])
    
}

print(ans/2)

 

반응형

'PS > 백준' 카테고리의 다른 글

[백준] 1806 부분합  (0) 2024.10.14
[백준] 2470 두 용액  (0) 2024.10.14
[백준] 1202 보석 도둑  (0) 2024.10.14
[백준] 15486 퇴사 2  (0) 2024.10.13
[백준] 11722 가장 긴 감소하는 부분 수열  (0) 2024.10.13
'PS/백준' 카테고리의 다른 글
  • [백준] 1806 부분합
  • [백준] 2470 두 용액
  • [백준] 1202 보석 도둑
  • [백준] 15486 퇴사 2
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (339)
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (41)
        • swift (34)
        • python (6)
        • Kotlin (1)
      • iOS (134)
        • UIKit (37)
        • Combine (1)
        • SwiftUI (34)
        • 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 (21)
        • 어노테이션 (6)
        • 튜토리얼 (14)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
      • AI (21)
        • 이론 (10)
        • MCP (1)
        • LangGraph (10)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[백준] 3273 두 수의 합
상단으로

티스토리툴바