1. 풀이방법.
- 말 그대로 그냥 문제 조건을 구현해야 하는데...
- 처음엔 왼쪽으로 쭉한번보고 오른쪽으로 쭉한번보고 위아래도 마찬가지로 하면된다 생각했었는데
- 223322 [L=2] 같은 경우가 안되는 것을 보고 접근 방식을 바꿨습니다.
-높이가 1차이 나는 친구를 만날경우 나보다 큰 친구면 나부터 뒤쪽을 보고
- 나보다 작은 친구면 나의 앞쪽부터 L만큼을 살펴 보았습니다.
2. 주의사항
- 나보다 큰 친구, 작은친구 의 분류로 나눠서 확인할 때, 저는 현재 위치를 INIT 앞쪽 친구를 loadmap[i][j]로 두었기 때문
- 에 비교문에서 값에 신경을 써야했습니다.
- 문제에 다양한 예시입력이 있어서 다행이었습니다.....아니였으면 꽤 오래 답을 찾아야 했을 것 같습니다.
- 후....문제에 대한 아이디어가 생각나면 그 아이디어로 해결이 될 것만 같은 [즉, 예외되는 사항이 발생하는 경우 를 잘
-떠올리지 못하는 것 같습니다]
- 코드를 작성하기 전에 한번 더 생각해보고 천천히 접근하자.....!
3. 나의코드
#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
int N;
int loadmap[101][101];
int L;
int result = 0;
int init;
bool check;
bool checkrow[101];
void inputs() {
for (int i = 0; i < N; i++) {
for (int j = 0; j < N; j++) {
cin >> loadmap[i][j];
}
}
}
int gap(int a, int b) {
if (a > b) return a - b;
else { return b - a; }
}
void initcheck() {
for (int i = 0; i < 101; i++) {
checkrow[i] = 0;
}
}
void lookr() {
for (int i = 0; i < N; i++) {
initcheck();
init = loadmap[i][0];
check = true;
for (int j = 1; j < N; j++) {
if (init == loadmap[i][j]) { init = loadmap[i][j]; continue; }
if (gap(init, loadmap[i][j]) == 1) { //높이1차이
if (init < loadmap[i][j]) { //벽을 만남(나보다 큰)
if (j - L < 0) { check = false; break; }
else {
for (int k = 1; k <= L; k++) {
if(checkrow[j-k]==true || loadmap[i][j - k] != init)
{ check = false; break; }
}
for (int k = 1; k <= L; k++) {
checkrow[j - k] = true;
}
if (check == false) break;
}
}
else { //나보다 작은 친구를 만남
if(j+L>N) { check = false; break; }
else{
for (int k = 0; k < L; k++) {
if (checkrow[j+k]==true||loadmap[i][j + k] != init-1)
{ check = false; break; }
}
for (int k = 0; k < L; k++) {
checkrow[j + k] = true;
}
if (check == false) break;
j += L-1; //앞에다가 경사로를 놓았을 경우 점프가 필요
}
}
}
else {check = false; break;} //높이1차이 이상
init = loadmap[i][j];
}
if (check == true) { result++; }
}
}
void looku() {
for (int i = 0; i < N; i++) {
initcheck();
init = loadmap[0][i];
check = true;
for (int j = 1; j < N; j++) {
if (init == loadmap[j][i]) { init = loadmap[j][i]; continue; }
if (gap(init, loadmap[j][i]) == 1) { //높이1차이
if (init < loadmap[j][i]) { //벽을 만남(나보다 큰)
if (j - L < 0) { check = false; break; }
else {
for (int k = 1; k <= L; k++) {
if (checkrow[j - k] == true || loadmap[j - k][i] != init)
{
check = false; break;
}
}
for (int k = 1; k <= L; k++) {
checkrow[j - k] = true;
}
if (check == false) break;
}
}
else { //나보다 작은 친구를 만남
if (j + L > N) { check = false; break; }
else {
for (int k = 0; k < L; k++) {
if (checkrow[j + k] == true || loadmap[j + k][i] != init - 1)
{
check = false; break;
}
}
for (int k = 0; k < L; k++) {
checkrow[j + k] = true;
}
if (check == false) break;
j += L-1; //앞에다가 경사로를 놓았을 경우 점프가 필요
}
}
}
else { check = false; break; } //높이1차이 이상
init = loadmap[j][i];
}
if (check == true) { result++; }
}
}
void checkingload() {
lookr();
looku();
cout << result;
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL); cout.tie(NULL);
cin >> N >> L;
inputs();
checkingload();
return 0;
}
'알고리즘 문제풀이 > 구현' 카테고리의 다른 글
백준 2840 [C++] (0) | 2020.12.06 |
---|---|
백준 2033 C++ (0) | 2020.11.25 |
백준 17406 [C++] (0) | 2020.10.18 |
백준 15686 [C++] (0) | 2020.10.17 |
백준 3190 [C++] (0) | 2020.10.17 |