inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

2-Q 질문

220

Park

작성한 질문수 1

0

http://boj.kr/26099a5957134d3c8954c7971fc64fbb

질문게시판에 있는 모든 반례를 다 넣어봤는데도 16%에서 계속 실패하네요

 

접근 방법은 동 서 남 북 에서 바라봤을때 1을 만나기 전 까지 모든 0을 queue에 집어넣어 bfs를 돌리는 방법으로 했습니다.

 

반례 리스트

10 12
0 0 0 0 0 0 0 0 0 0 0 0
0 1 1 1 1 1 1 1 1 1 1 0
0 1 1 0 0 1 0 0 0 1 1 0
0 1 0 1 0 1 0 1 1 0 1 0
0 1 0 1 0 1 0 0 0 0 0 0
0 1 0 1 0 0 1 1 1 0 1 0
0 1 0 1 1 1 1 1 1 0 1 0
0 1 0 0 0 0 0 0 0 0 1 0
0 1 1 1 1 1 1 1 1 1 1 0
0 0 0 0 0 0 0 0 0 0 0 0

answer: 1 50

5 5
0 0 0 0 0
0 1 1 0 0
0 1 0 1 0
0 1 1 1 0
0 0 0 0 0
answer 1,7

4 6
0 0 0 0 0 0
0 0 0 1 1 0
0 1 1 1 1 0
0 0 0 0 0 0
answer 1,6

6 4
0 0 0 0
0 1 1 0
0 0 1 0
0 1 0 0
0 1 0 0
0 0 0 0
answer 1,5


6 6
0 0 0 0 0 0
0 0 1 0 0 0
0 0 0 0 0 0
0 0 0 0 1 0
0 0 0 1 0 0
0 0 0 0 0 0
answer 1,3

3 3
0 0 0
0 1 0
0 0 0
answer 1,1

3 3
0 0 0
0 0 0
0 0 0
answer 0,0

C++ 코테 준비 같이 해요!

답변 1

0

큰돌

안녕하세요 ㅎㅎ 주석 달았는데 참고 부탁드립니다.

#include <bits/stdc++.h>

using namespace std;
typedef long long ll;

int n, m;
int arr[101][101];
bool ok[101][101];
int dx[4] = {0, 0, 1, -1};
int dy[4] = {1, -1, 0, 0};
set<pair<int, int>> S;

void solve(int i, int j, set<pair<int, int>> &S) {
  queue<pair<int, int>> Q;
  Q.push({i, j});
  ok[i][j] = true;
  while (!Q.empty()) {
    auto cur = Q.front();
    Q.pop();
    for (int t = 0; t < 4; t++) {
      int nx = cur.first + dx[t];
      int ny = cur.second + dy[t];
      if (nx < 0 || nx >= n || ny < 0 || ny >= m || ok[nx][ny])
        continue;
      if (arr[nx][ny] == 1) {
        S.insert({nx, ny});
        continue;
      }
      ok[nx][ny] = true;
      Q.push({nx, ny});
    }
  }
}

int main(void) {
  ios_base::sync_with_stdio(0);
  cin.tie(0);
  cout.tie(NULL);

//GOOD
  cin >> n >> m;
  for (int i = 0; i < n; i++) {
    for (int j = 0; j < m; j++) {
      cin >> arr[i][j];
    }
  }

  int cnt = 0;
  int last_cnt = 0;

  while (true) {
    S.clear(); 
    bool ok[101][101];
    // 이런식으로 초기화 해주는 것이 좋습니다.  
	memset(ok, sizeof(ok), 0);
    for (int i = 0; i < n; i++)
      for (int j = 0; j < m; j++)
        ok[i][j] = false;

// 왜 이렇게 하시죠? 이 문제는 가장자리가 모두 0이기 때문에 가장자리에서 한번만 solve를 작동하면 
// 됩니다. 
		// 서 -> 동
    for (int i = 0; i < n; i++) {
      for (int j = 0; j < m; j++) {
        if (arr[i][j] == 1 || ok[i][j]) {
          break;
        }
        solve(i, j, S);
      }
    }

		// 북 -> 서
    for (int j = 0; j < m; j++) {
      for (int i = 0; i < n; i++) {
        if (arr[i][j] == 1 || ok[i][j]) {
          break;
        }
        solve(i, j, S);
      }
    }

		// 남 -> 북
    for (int i = 0; i < n; i++) {
      for (int j = m - 1; j >= 0; j--) {
        if (arr[i][j] == 1 || ok[i][j]) {
          break;
        }
        solve(i, j, S);
      }
    }

		// 동 -> 서
    for (int j = 0; j < m; j++) {
      for (int i = n - 1; i >= 0; i--) {
        if (arr[i][j] == 1 || ok[i][j]) {
          break;
        }
        solve(i, j, S);
      }
    }
    if (S.size() == 0)
      break;
    cnt++;
    last_cnt = S.size();
    for (auto a : S)
      arr[a.first][a.second] = 0;
  }
  cout << cnt << "\n";
  cout << last_cnt;
  return 0;
}

0

Park

가장자리가 0이라는 조건을 못봤네요 답변 감사합니다! 문제 꼼꼼히 봐야겠네요!!

0

Park

http://boj.kr/9bdace1ae4124ba696f31c202e8b1776
다시 제출하고 통과했습니다 감사합니다!

1-E질문입니다!

0

518

2

3-L 틀린 부분 피드백 부탁드립니다.

0

821

2

1-A문제 순열재귀함수 질문입니다.

0

384

1

1-A 일곱난쟁이문제입니다

0

456

1

문제 풀 때 방향성에 대해

0

800

1

맥에서 vs code로 실행 관련 질문입니다

0

523

1

17071번 메모리 초과

0

386

1

1-C질문입니다!

0

421

2

2-B BFS 시간초과질문

0

630

2

1-O 13번 라인

0

442

1

6-J 놀이공원 문제 질문

0

381

1

구현관련 질문

0

484

1

강의 교안

0

319

1

실력을 더 올리고나서 강의를 보는 것이 맞을까요?

0

545

1

안녕하세요! 재귀함수에 관해서 질문드립니다

0

536

1

1-K

0

473

2

3-G번 질문있습니다.

1

473

3

3-C 실행 시간 질문드립니다.

0

493

1

4-A 문제 풀이 질문있습니다.

0

590

2

비트마스킹 연산자 "1의 보수" 영문 표기법

0

435

1

격자탐색 문제에서 BFS 시간복잡도 질문드립니다.

0

334

1

3-O go 함수 질문 드립니다.

1

447

2

4-A 출력 질문

0

305

1

1주차 1-O 질문드립니다

0

259

1