Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- JS
- solved.ac골드
- [pccp 기출문제]
- 두원사이의정수쌍
- div2개
- 정렬
- solved.ac플래티넘
- 비트마스크
- DP
- 5강클로저
- React.StrictMode
- c++
- 알고리즘 문제풀이
- 2023카카오블라인드코테
- 알고리즘문제풀이
- 최소스패닝트리
- 우박수열정적분
- 지도 여러개
- 프로그래머스
- 타겟넘버
- 이중지도
- 백준 알고리즘
- 과제진행하기
- Lv2
- 코어자바스크립트
- JS스터디
- 스택
- Lv3
- pccp기출문제
- 백준알고리즘
Archives
- Today
- Total
호지
[백준 알고리즘] 2467번 용액 문제풀이 c++ 본문
이분탐색을 활용한 문제풀이이다.
용액의 특성값은 오름차수로 주어지므로
용액의 특성값을 list배열에 입력받아
list배열의 왼쪽과 오른쪽에 포인터를 두고 이분탐색을 한다.
두 용액의 합의 절대값이 0에 가까울 때, 두 용액의 특성값을 출력해야 한다.
sum변수에는 가장 절대값이 0에 가까울 때 값을 저장하고
1.왼쪽 포인터를 오른쪽으로 옮길때와(abs(list[right] + list[left+1])
2.오른쪽 포인터를 왼쪽으로 옮길때(abs(list[right-1] + list[left])
를 비교하여 1일때는 left를 1증가, 2일때는 right를 1감소시켜 이분탐색을 한다.
#include <iostream>
using namespace std;
int list[100001];
int main(){
int n;
cin >> n;
for(int i=0; i<n; i++){
cin >> list[i];
}
int left = 0, right = n-1;
long long sum = (long long)list[right] + list[left];
int ret1 = left, ret2 = right;
while(left<right){
long long tmp = (long long)list[right] + list[left];
if(abs(tmp) < abs(sum)){
sum = tmp;
ret1 = left;
ret2 = right;
}
if(abs(list[right-1] + list[left]) > abs(list[right] + list[left+1])){
left++;
}
else{
right--;
}
}
cout << list[ret1] << " " << list[ret2];
return 0;
}
'알고리즘 > 백준' 카테고리의 다른 글
[백준 알고리즘] 2473번 세 용액 문제풀이 (0) | 2022.11.28 |
---|---|
[백준 알고리즘] 2342번 Dance Dance Revolution 문제풀이 c++ (0) | 2022.06.10 |
[백준 알고리즘] 2252번 줄세우기 문제풀이 c++ (0) | 2022.06.10 |
[백준 알고리즘] 2239번 스도쿠 문제풀이 (0) | 2022.06.08 |
[백준 알고리즘] 2166번 다각형의 면적 (0) | 2022.06.08 |
Comments