일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 프로그래머스
- 다이나믹 프로그래밍
- 컨디션 변수
- 병행성
- 영속성
- DirectX12
- 디자인패턴
- 타입 객체
- Direct12
- 운영체제
- 백준
- codility
- 다이나믹프로그래밍
- 락
- 파일시스템 구현
- DirectX 12
- 동적계획법
- 쓰레드
- 알고리즘
- 멀티쓰레드
- directx
- 병행성 관련 오류
- 렌더링 파이프라인
- 그리디알고리즘
- 그리디 알고리즘
- 자료구조
- OS
- 스케줄링
- I/O장치
- 멀티프로세서
Archives
- Today
- Total
기록공간
수리공 항승 (백준 - 1449번) 본문
반응형
그리디 알고리즘을 사용하는 문제였다.
우선 물이 새는 곳의 위치를 입력받으면 그 정보를 정렬한다. 그 다음 처음 물이 새는 곳의 위치를 기록한다.(start값)
물이 새는 곳이 하나라도 있으면 테이프를 한 개는 써야 하므로 테이프의 갯수를 기록할때는 1부터 시작한다.
테이프를 최소로 쓰기 위해서 어떻게 해야 하는지 살펴보자. 물이 새는 위치를 순회하며 start에서 물이 새는 위치까지의 길이가 테이프의 길이 - 1(좌우 0.5만큼 간격을 줘야 하므로) 보다 큰 경우 이미 테이프의 길이를 넘어 갔으므로 start부분만 막고 새로운 테이프로 현재 위치를 막아야 한다. 그리고 start값을 현재 위치의 값으로 갱신한다. 모든 위치를 방문했을때 테이프의 갯수가 우리가 원하는 값이 된다.
코드는 다음과 같다.
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main()
{
vector<int> leakPos;
int leakCount;
int tapeLength;
cin >> leakCount >> tapeLength;
leakPos.resize(leakCount);
for (int i = 0; i < leakCount; ++i)
{
cin >> leakPos[i];
}
sort(leakPos.begin(), leakPos.end());
int tapeCount = 1;
int start = leakPos[0];
for (int i = 1; i < leakCount; ++i)
{
if (tapeLength - 1 < leakPos[i] - start)
{
++tapeCount;
start = leakPos[i];
}
}
cout << tapeCount << endl;
}
반응형
'Algorithm > 문제' 카테고리의 다른 글
DNA (백준 - 1969번) (0) | 2020.03.29 |
---|---|
멀티탭 스케줄링 (백준 - 1700번) (0) | 2020.03.29 |
저울 (백준 - 2437번) (0) | 2020.03.29 |
병든 나이트 (백준 - 1783번) (1) | 2020.03.29 |
한 줄로 서기 (백준 - 1138번) (0) | 2020.03.29 |
Comments