3주차 개념 강의에서 첫 문제(연구소_14502) 질문드립니다!!
안녕하세요 선생님ㅠㅠ
제가 푼 코드를 실행시키니 틀렸다고 결과가 나왔는데 아무리 계속 원인을 찾아보고 디버깅도 해봐도 이유를 잘 모르겠습니다ㅠㅠㅜ 반례 중에 어떤 특정한 케이스에서 틀렸다고 판단된 것 같은데 혹시 무엇이 잘못되었는지 짚어주실 수 있으실까요..??
항상 감사합니다 :)
http://boj.kr/34786960e9b84876be27b66b0271ece2
답변 1
1
안녕하세요 ㅎㅎ 주석 달았는데 참고 부탁드립니다.
그리고 담부턴 질문 주실 때 해당 강의 2 - k 등 그런 강의 옆에 질문하기로 좀 부탁드립니다. ㅎㅎ
#include <iostream>
#include <vector>
#include <queue>
#include <algorithm>
using namespace std;
int mapp[8][8], sero, garo, MAX_candidate;
// {0, } 이거 하지 말아주세요. 교안참고해주세요.
int MAX = -1, virus_scale = 0, visited[8][8] = {0,}, dy[4] = { 1, 0, -1, 0 }, dx[4] = { 0, 1, 0, -1 };
vector<pair<int, int>> v;
void DFS(int ny, int nx);
int main(void)
{
cin >> sero >> garo;
for (int i = 0; i < sero; i++)
{
for (int k = 0; k < garo; k++)
{
cin >> mapp[i][k];
if (!mapp[i][k])
{
v.push_back({ i, k }); // 현재 값이 0인 지점은 전부 vector에 넣는다.
// 자동으로 초기의 안전영역 크기(v.size())를 알 수 있고, 바이러스 퍼진 후 안전영역은
}// 초기 v.size() - 커넥티드 컴포넌트 전체 크기(2개수) - 3이다.
}
}
//이걸 왜하시죠? 벽을 3개를 세운담에 해야되는데요.
for (int u = 0; u < sero; u++)
{
for (int j = 0; j < garo; j++)
{
if (!visited[u][j] && mapp[u][j] == 2)
{
DFS(u, j);
}
}
}
// 왜 long unsigned intf를 쓰죠?
for (long unsigned int e = 0; e < v.size(); e++)
{
for (long unsigned int w = e + 1; w < v.size(); w++)
{
for (long unsigned int q = w + 1; q < v.size(); q++)
{
// 여기서 각각 v[e], v[w], v[q] 쌍은 pair쌍 좌표임.
mapp[v[e].first][v[e].second] = 1;
mapp[v[w].first][v[w].second] = 1;
mapp[v[q].first][v[q].second] = 1;
for (int u = 0; u < sero; u++)
{
for (int j = 0; j < garo; j++)
{
if (!visited[u][j] && mapp[u][j] == 2)
{
DFS(u, j);
}
}
}
MAX_candidate = v.size() - virus_scale - 3;
if (MAX < MAX_candidate)
{
MAX = MAX_candidate;
}
fill(&visited[0][0], &visited[0][0] + 8 * 8, 0); // 이 줄 부터 오류임
mapp[v[e].first][v[e].second] = 0;
mapp[v[w].first][v[w].second] = 0;
mapp[v[q].first][v[q].second] = 0;
virus_scale = 0;
}
}
}
cout << MAX << '\n';
return 0;
}
void DFS(int ny, int nx)
{
visited[ny][nx] = 1;
int tmp_y, tmp_x;
for (int t = 0; t < 4; t++)
{
tmp_y = ny + dy[t];
tmp_x = nx + dx[t];
if (tmp_y >= 0 && tmp_x >= 0 && tmp_y < sero && tmp_x < garo && !visited[tmp_y][tmp_x])
{
if (mapp[tmp_y][tmp_x] != 1)
{
if (mapp[tmp_y][tmp_x] != 2)
{
virus_scale++;
}
DFS(tmp_y, tmp_x);
}
// 아까 &asum할 때 주소로 안하면 이 변경 반영 안되었는데
// 근데 또 지금까지 했을 때는 ++ 잘 되었던 것 같은데 뭐지
//
}
}
}
5-B
0
4
1
4 - A
0
30
2
코딩살구클럽 입장이 안됩니다
0
78
2
4-F 경우의 수 질문입니다.
0
34
2
코딩살구클럽 가입이 안됩니다.
0
81
2
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
61
1
교안 158페이지 문의드립니다
0
46
2
코딩살구클럽 관련 건의사항
0
119
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
45
1
진행 방법 질문드립니다!
0
81
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
64
2
2주차 개념#12 트리 순회
0
33
2
백준사이트가 종료된다고 합니다.
0
318
2
백준 서비스 종료
9
953
1
sk 하이닉스 코테 대비
0
388
2
3-G 최댓값 질문
0
54
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
84
2
3-I 코드 질문드립니다.
0
66
2
3-N 질문 있습니다.
0
68
2
학습방법
0
105
2
4-H 질문 있습니다 (코드 리뷰)
0
69
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
186
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
73
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
66
2





