[백준] 2047번: 두 용액 - Kotlin[코틀린]

2024. 1. 14. 23:07·알고리즘/Baekjoon

문제

 

 

2470번: 두 용액

첫째 줄에는 전체 용액의 수 N이 입력된다. N은 2 이상 100,000 이하이다. 둘째 줄에는 용액의 특성값을 나타내는 N개의 정수가 빈칸을 사이에 두고 주어진다. 이 수들은 모두 -1,000,000,000 이상 1,000,00

www.acmicpc.net

 


풀이

 

 투 포인터 알고리즘으로 해결할 수 있다. 입력받은 용액을 오름차순으로 정렬한다. 시작과 끝을 가르키는 두 포인터를 선언하여 반복문을 통해 탐색한다. 두 포인터가 가르키는 용액의 합이 0에 가까워질 때마다 결과를 갱신해준다. 만약 합이 0보다 작다면 시작 포인터를 뒤로 움직이고, 0보다 크다면 끝 포인터를 앞으로 움직여준다.

 


코드

 

import kotlin.math.*

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() }.sorted()
    var sum = Int.MAX_VALUE
    var acid = 0
    var alkali = 0
    var start = 0
    var end = num - 1

    while (start < end) {
        val tmp = arr[start] + arr[end]
        if(abs(tmp)<sum) {
            alkali = arr[start]
            acid = arr[end]
            sum = abs(tmp)
        }
        if(tmp < 0) {
            start++
        } else {
            end--
        }
    }

    bw.write("$alkali $acid")
    bw.flush()
    bw.close()
    br.close()
}

 

 

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

[백준] 12789번: 도키도키 간식드리미 - Kotlin[코틀린]  (0) 2024.01.16
[백준] 1806번: 부분합 - Kotlin[코틀린]  (0) 2024.01.15
[백준] 2018번: 수들의 합 5 - Kotlin[코틀린]  (0) 2024.01.13
[백준] 3055번: 탈출 - Kotlin[코틀린]  (0) 2024.01.12
[백준] 3273번: 두 수의 합 - Kotlin[코틀린]  (0) 2024.01.11
'알고리즘/Baekjoon' 카테고리의 다른 글
  • [백준] 12789번: 도키도키 간식드리미 - Kotlin[코틀린]
  • [백준] 1806번: 부분합 - Kotlin[코틀린]
  • [백준] 2018번: 수들의 합 5 - Kotlin[코틀린]
  • [백준] 3055번: 탈출 - Kotlin[코틀린]
junghoooooon
junghoooooon
  • junghoooooon
    코드팁스
    junghoooooon
  • 전체
    오늘
    어제
    • 전체 (120)
      • 안드로이드 (0)
        • 코드팁스 (0)
      • 유니티 (0)
        • 코드팁스 (0)
      • 알고리즘 (118)
        • 알고리즘 (0)
        • Baekjoon (118)
      • GitHub (0)
      • 티스토리 (2)
  • 블로그 메뉴

    • 링크

    • 공지사항

    • 인기 글

    • 태그

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

    티스토리툴바