[백준] 3273번: 두 수의 합 - Kotlin[코틀린]

2024. 1. 11. 21:03·알고리즘/Baekjoon

문제

 

 

3273번: 두 수의 합

n개의 서로 다른 양의 정수 a1, a2, ..., an으로 이루어진 수열이 있다. ai의 값은 1보다 크거나 같고, 1000000보다 작거나 같은 자연수이다. 자연수 x가 주어졌을 때, ai + aj = x (1 ≤ i < j ≤ n)을 만족하는

www.acmicpc.net

 


풀이

 

 입력받은 수열을 오름차순으로 정렬한 후, 두 포인터를 사용하여 원하는 합을 만드는 투 포인터 문제이다. 앞과 뒤에서 시작하는 두 개의 포인터를 조작하여 합을 조절하며 원하는 값에 도달하는데, 합이 목표값보다 크면 뒤의 포인터를 앞으로, 작으면 앞의 포인터를 뒤로 움직입니다. 두 포인터가 만날 때 반복문을 종료해준다.

 

 투 포인터 알고리즘은 한 번의 루프마다 두 포인터 중 하나만 1씩 증가하며, 각 포인터의 합이 목표값이 되면 알고리즘이 종료된다. 따라서 시간복잡도는 $O(N)$이다.

 


코드

 

fun main() {
    val br = System.`in`.bufferedReader()
    val bw = System.out.bufferedWriter()

    val num = br.readLine().toInt()
    val arr = br.readLine().split(' ').map { it.toInt() }.toIntArray()
    arr.sort()

    val sum = br.readLine().toInt()
    var cnt = 0
    var start = 0
    var end = num - 1

    while (start < end) {
        val tmp = arr[start] + arr[end]
        if (tmp == sum) {
            cnt++
        }
        if (tmp <= sum) {
            start++
        } else {
            end--
        }
    }

    bw.write("$cnt")
    bw.flush()
    bw.close()
    br.close()
}

 

'알고리즘 > Baekjoon' 카테고리의 다른 글

[백준] 2018번: 수들의 합 5 - Kotlin[코틀린]  (0) 2024.01.13
[백준] 3055번: 탈출 - Kotlin[코틀린]  (0) 2024.01.12
[백준] 1850번: 최대공약수 - Kotlin[코틀린]  (0) 2024.01.07
[백준] 1652번: 누울 자리를 찾아라 - Kotlin[코틀린]  (0) 2024.01.04
[백준] 2075번: N번째 큰 수 - Kotlin[코틀린]  (0) 2024.01.04
'알고리즘/Baekjoon' 카테고리의 다른 글
  • [백준] 2018번: 수들의 합 5 - Kotlin[코틀린]
  • [백준] 3055번: 탈출 - Kotlin[코틀린]
  • [백준] 1850번: 최대공약수 - Kotlin[코틀린]
  • [백준] 1652번: 누울 자리를 찾아라 - Kotlin[코틀린]
junghoooooon
junghoooooon
  • junghoooooon
    코드팁스
    junghoooooon
  • 전체
    오늘
    어제
    • 전체 (120)
      • 안드로이드 (0)
        • 코드팁스 (0)
      • 유니티 (0)
        • 코드팁스 (0)
      • 알고리즘 (118)
        • 알고리즘 (0)
        • Baekjoon (118)
      • GitHub (0)
      • 티스토리 (2)
  • 블로그 메뉴

    • 링크

    • 공지사항

    • 인기 글

    • 태그

      MST
      큐
      누적 합
      투 포인터
      그리디
      문자열
      그래프 탐색
      분리집합
      수학
      피보나치
      백트래킹
      스택
      소수 판정
      dfs
      분할 정복
      구현
      DP
      그래프이론
      BFS
      브루트포스
      모듈러 곱셈 역원
      정렬
      유니온파인드
      이분 탐색
      에라토스테네스의 체
      재귀
      프림
      우선순위 큐
      티스토리
      크루스칼
    • hELLO· Designed By정상우.v4.10.2
    junghoooooon
    [백준] 3273번: 두 수의 합 - Kotlin[코틀린]
    상단으로

    티스토리툴바