5-k 맞왜틀 질문있습니다.
67
작성한 질문수 15
안녕하세요.
아쉽게도 강의처럼 2차원 배열에 모아둔 후, 한칸씩 당기는것을 생각을 못해 노가다로 풀어버렸습니다.
다만 알고리즘 자체는 맞다고 생각하고, 예제도 다 맞는데 16%에서 틀려버리네요.
어디가 틀렸는지 궁금합니다.
http://boj.kr/76b5753735c448b7a9558225494e778e
감사합니다.
답변 2
0
안녕하세요 비스킷님 ㅎㅎ
3개의 로직이 잘못된 것 같구요. 해당 부분을 제가 고쳐봤습니다.
먼지확산부분로직 floor 변경
int spread_dust = floor(board[y][x] / 5);
->
cur_dust / 5
유효한 칸만 먼지가 확산되도록
if (ny >= 0 && ny < r && nx >= 0 && nx < c && board[ny][nx] != -1) 추가.
CirculateCCW, CirculateCW 로직 수정
#include<iostream>
#include<cmath>
#include<vector>
using namespace std;
typedef vector<vector<int>> Board;
struct Pos {
int y;
int x;
};
int r, c, t;
int dx[4] = { 0, 0, 1, -1 };
int dy[4] = { 1, -1, 0, 0 };
Pos upperAC;
Pos lowerAC;
void SpreadDust(Board& board)
{
Board updated(r, vector<int>(c, 0));
for (int y = 0; y < r; ++y) {
for (int x = 0; x < c; ++x) {
if (board[y][x] == -1) {
updated[y][x] = -1;
continue;
}
int cur_dust = board[y][x];
int spread_dust = cur_dust / 5;
int spread_count = 0;
for (int i = 0; i < 4; ++i) {
int ny = y + dy[i];
int nx = x + dx[i];
if (ny >= 0 && ny < r && nx >= 0 && nx < c && board[ny][nx] != -1) {
updated[ny][nx] += spread_dust;
spread_count++;
}
}
updated[y][x] += cur_dust - (spread_dust * spread_count);
}
}
board = updated;
}
void CirculateCCW(Board& board) {
for (int y = upperAC.y - 1; y > 0; --y) board[y][0] = board[y - 1][0];
for (int x = 0; x < c - 1; ++x) board[0][x] = board[0][x + 1];
for (int y = 0; y < upperAC.y; ++y) board[y][c - 1] = board[y + 1][c - 1];
for (int x = c - 1; x > 1; --x) board[upperAC.y][x] = board[upperAC.y][x - 1];
board[upperAC.y][1] = 0;
}
void CirculateCW(Board& board) {
for (int y = lowerAC.y + 1; y < r - 1; ++y) board[y][0] = board[y + 1][0];
for (int x = 0; x < c - 1; ++x) board[r - 1][x] = board[r - 1][x + 1];
for (int y = r - 1; y > lowerAC.y; --y) board[y][c - 1] = board[y - 1][c - 1];
for (int x = c - 1; x > 1; --x) board[lowerAC.y][x] = board[lowerAC.y][x - 1];
board[lowerAC.y][1] = 0;
}
long long GetDustAmount(const Board& board) {
long long result = 0;
for (int y = 0; y < r; ++y) {
for (int x = 0; x < c; ++x) {
if (board[y][x] > 0) {
result += board[y][x];
}
}
}
return result;
}
int main() {
cin >> r >> c >> t;
Board board(r, vector<int>(c, 0));
bool foundAC = false;
for (int y = 0; y < r; ++y) {
for (int x = 0; x < c; ++x) {
cin >> board[y][x];
if (!foundAC && board[y][x] == -1) {
upperAC = { y, x };
lowerAC = { y + 1, x };
foundAC = true;
}
}
}
for (int i = 0; i < t; ++i) {
SpreadDust(board);
CirculateCCW(board);
CirculateCW(board);
}
cout << GetDustAmount(board);
return 0;
}
이렇게 해보시겠어요?
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
0
안녕하세요, 인프런 AI 인턴입니다.
비스킷님, 알고리즘을 직접 구현하시느라 고생 많으셨습니다. 노가다 방식으로 문제를 해결하는 과정에서 간혹 발생할 수 있는 실수를 몇 가지 체크해 보면 좋겠습니다. 특히, 알고리즘이 여러 특수한 경우에 대해 모두 올바르게 작동하는지 확인해 보는 것이 중요합니다. 아래 몇 가지 팁을 드립니다.
경계 조건 확인: 배열의 경계나 특정 값일 때 올바르게 처리되는지 확인하세요. 코드가 의도치 않게 배열을 벗어난 부분에 접근하려 하거나, 경계 조건을 놓쳤을 수 있습니다.
특정 입력 케이스 테스트: 예제에서는 맞을 수 있지만, 알고리즘이 처리할 수 있도록 설정하지 않은 특수한 입력 때문에 실패할 수 있습니다. 다양한 형태의 입력 데이터로 테스트해 보세요.
무한 루프 또는 잘못된 반복문: 조건이 정확하게 설정되지 않아서 무한 루프에 빠지거나, 반복문이 의도했던 횟수보다 더 실행될 수 있습니다.
자료형 문제: 변수의 자료형이 클 때 정확하게 대응하지 못해 발생할 수 있는 문제가 없도록 주의하세요.
출력 형식 및 디테일: 문제의 요구 사항에 따라 출력 형식이 기대한 것과 다를 경우에도 틀릴 수 있습니다.
관련 내용을 더 참고하고 싶으시다면 아래 질문이 도움이 될 수 있습니다:
- 4-H 질문있습니다 - 강사의 반례에 대한 논의가 포함된 게시물입니다.
- 질문 있습니다. - 코드의 확인 및 개선에 대한 피드백이 포함된 게시물입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
진행 방법 질문드립니다!
0
23
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
53
2
2주차 개념#12 트리 순회
0
25
2
백준사이트가 종료된다고 합니다.
0
284
2
백준 서비스 종료
9
879
1
sk 하이닉스 코테 대비
0
367
2
3-G 최댓값 질문
0
50
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
83
2
3-I 코드 질문드립니다.
0
62
2
3-N 질문 있습니다.
0
66
2
학습방법
0
102
2
4-H 질문 있습니다 (코드 리뷰)
0
66
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
169
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
69
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
64
2
1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.
0
51
2
조합 재귀 풀이 확인 해주시면 감사하겠습니다.
0
68
2
함수별 시간복잡도
0
73
2
3-h 질문입니다.
0
49
1
안녕하세요 선생님. 시간 복잡도 4번 질문있습니다.
0
53
2
1-I 문제 질문 드립니다.
0
76
2
2-P 질문입니다.
0
56
1
mac에서 시작하기 관련
0
91
2
5-Q 질문
0
64
2





