일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- dfs문제
- dfs
- TensorFlow Lite
- 알고리즘
- 코딩테스트
- 포스코 ai 교육
- MCU 딥러닝
- 삼성역테
- 포스코 교육
- 삼성코테
- 임베디드 딥러닝
- 자료구조
- 컴퓨팅사고
- 코테
- 영상처리
- bfs문제
- 초소형머신러닝
- BFS
- 그리디
- 다이나믹프로그래밍
- tflite
- DP문제
- 포스코 AI교육
- 코테 문제
- 삼성코딩테스트
- 딥러닝
- tinyml
- sort
- DP
- 삼성역량테스트
- Today
- Total
코딩뚠뚠
[백준문제풀이] 1783 병든나이트 본문
풀이일시 : 2020-09-10
문제 :
병든 나이트가 N × M 크기 체스판의 가장 왼쪽아래 칸에 위치해 있다. 병든 나이트는 건강한 보통 체스의 나이트와 다르게 4가지로만 움직일 수 있다.
1. 2칸 위로, 1칸 오른쪽
2. 1칸 위로, 2칸 오른쪽
3. 1칸 아래로, 2칸 오른쪽
4. 2칸 아래로, 1칸 오른쪽
병든 나이트는 여행을 시작하려고 하고, 여행을 하면서 방문한 칸의 수를 최대로 하려고 한다. 병든 나이트의 이동 횟수가 4번보다 적지 않다면, 이동 방법을 모두 한 번씩 사용해야 한다. 이동 횟수가 4번보다 적은 경우(방문한 칸이 5개 미만)에는 이동 방법에 대한 제약이 없다.
체스판의 크기가 주어졌을 때, 병든 나이트가 여행에서 방문할 수 있는 칸의 최대 개수를 구해보자.
입력:
첫째 줄에 체스판의 세로 길이 N와 가로 길이 M이 주어진다. N과 M은 2,000,000,000보다 작거나 같은 자연수이다.
ex)
100 50
출력:
병든 나이트가 여행에서 방문할 수 있는 칸의 개수중 최댓값을 출력한다.
ex) 48
풀이 :
그리디알고리즘
이동횟수가 5 이상이면 네 개의 패턴을 모두 사용해서 이동해야한다. 4 이하이면 뭘 사용해도 상관없다.
n=1 이면 시작점에서부터 아무곳도 가지못한다.
n=2 이면
|
|
O |
|
|
|
O |
O |
|
|
|
O |
|
|
위 표와같이 움직일 수 있을 것이고 4번까지만 사용하고싶은것을 사용할 수 있을 것이다.
m에 따른 result=(m+1)/2 가 될 것이고 만약 result>=4 이면 result=4 (최대) 가 될 것이다.
n>=3 이면
|
O |
|
|
|
O |
|
|
|
|
|
O |
|
|
|
|
O |
|
|
|
|
|
O |
|
계속 나아가도 7 이후에는 result = m-2 가 될 것이고 7 미만이라면 4를 초과해서는 안되는 한에서 어떤 이동이던 가능 할 것이다.
#include <iostream>
using namespace std;
int n, m;
int main() {
cin >> n >> m;
if (n == 1)
cout << '1';
else if (n == 2) {
if ((m + 1) / 2 > 4) //m이 8이상이게되면 이동횟수가 4번 이상이다.
cout << 4; //그래서 이동방법에 제약이 생겨 최대 방문갯수는 4로 고정
else // 그 이하의 크기일때는
cout << (m + 1) / 2; //높이가 2일때 m을 2로나누면 방문한 갯수가 될 것이다.
}
else { //이외에는 제약이 없다.
if (m >= 7) // m이 7보다 크면 (무조건 한번씩은 써야됨)
cout << m - 2; //방문한 칸의 갯수는 -2만큼이 될것
else //m이 그 이하이면
cout << min(m, 4); //(4와 그 이하의 m 중 하나)
}
}
'알고리즘 문제풀이 > 백준문제풀이' 카테고리의 다른 글
[백준문제풀이] 2812 크게 만들기 (0) | 2020.12.31 |
---|---|
[백준문제풀이] 1969 DNA (0) | 2020.12.31 |
[백준문제풀이] 2437 저울 (0) | 2020.12.31 |
[백준문제풀이] 1946 신입사원 (0) | 2020.12.31 |
[백준문제풀이] 10610 30 (0) | 2020.12.31 |