티스토리 뷰
반응형
https://www.acmicpc.net/problem/2467
⊙ 문제
⊙ 입력
⊙ 출력
⊙ 예제 입출력
⊙ 알고리즘 분류
- 이분 탐색
- 두 포인터
⊙ 문제 접근 과정
반복문을 2중 이상으로 사용하면 시간 초과가 뜬다.
하나만을 이용해 풀어야한다. 그 방법 중 하나로 투 포인터 알고리즘이 있다.
투 포인터
- start, end -> index값 생성
- index를 이용해 절댓값을 사용해준다.
- 반복
⊙ 문제 풀이
#include <iostream>
#include <vector>
#include <algorithm>
typedef long long ll;
using namespace std;
ll n;
int main() {
cin >> n;
ll arr[n+1];
for(int i=0;i<n;i++) {
cin >> arr[i];
}
ll result = 99999999999;
ll start=0, end=n-1;
ll one,two;
while (start <end) {
ll temp = arr[start] + arr[end];
ll num = abs(temp);
if(result>num) {
result = num;
one = arr[start];
two = arr[end];
}
if(temp>0)
end--;
else start++;
}
cout << one << " " << two;
}
⊙ 결과
⊙ 마무리
NONE
좋아요는 로그인하지 않아도 누를 수 있습니다!
728x90
반응형
'백준 온라인 저지 [BOJ] > C++ [CPP]' 카테고리의 다른 글
[백준(BOJ)] 3273번 : 두 수의 합 - C++[CPP] (0) | 2021.05.21 |
---|---|
[백준(BOJ)] 3079번 : 입국심사 - C++[CPP] (2) | 2021.05.20 |
[백준(BOJ)] 1541번 : 잃어버린 괄호 - C++[CPP] (0) | 2021.05.18 |
[백준(BOJ)] 1654번 : 랜선 자르기 - C++[CPP] (0) | 2021.05.18 |
[백준(BOJ)] 1806번 : 부분합 - C++[CPP] (0) | 2021.05.18 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 구현
- 쉽게 배우는 자바 프로그래밍
- OS
- 그리디
- 문자열
- BFS
- Python
- 파이썬
- 정답
- 답
- C++
- 운영체제
- 자바스크립트
- 백준
- 해답
- 정렬
- py
- 알고리즘
- JS
- 자바
- 쉽게배우는자바프로그래밍
- CPP
- java
- 쉽게배우는
- 우종정
- 연습문제
- 풀이
- Web
- 정리
- 프로그래머스
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
글 보관함