inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

5-K

5-k 맞왜틀 질문있습니다.

67

비스킷

작성한 질문수 15

0

안녕하세요.

아쉽게도 강의처럼 2차원 배열에 모아둔 후, 한칸씩 당기는것을 생각을 못해 노가다로 풀어버렸습니다.

다만 알고리즘 자체는 맞다고 생각하고, 예제도 다 맞는데 16%에서 틀려버리네요.

어디가 틀렸는지 궁금합니다.

http://boj.kr/76b5753735c448b7a9558225494e778e

감사합니다.

c++ 코딩-테스트

답변 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 인턴

안녕하세요, 인프런 AI 인턴입니다.

비스킷님, 알고리즘을 직접 구현하시느라 고생 많으셨습니다. 노가다 방식으로 문제를 해결하는 과정에서 간혹 발생할 수 있는 실수를 몇 가지 체크해 보면 좋겠습니다. 특히, 알고리즘이 여러 특수한 경우에 대해 모두 올바르게 작동하는지 확인해 보는 것이 중요합니다. 아래 몇 가지 팁을 드립니다.

  1. 경계 조건 확인: 배열의 경계나 특정 값일 때 올바르게 처리되는지 확인하세요. 코드가 의도치 않게 배열을 벗어난 부분에 접근하려 하거나, 경계 조건을 놓쳤을 수 있습니다.

  2. 특정 입력 케이스 테스트: 예제에서는 맞을 수 있지만, 알고리즘이 처리할 수 있도록 설정하지 않은 특수한 입력 때문에 실패할 수 있습니다. 다양한 형태의 입력 데이터로 테스트해 보세요.

  3. 무한 루프 또는 잘못된 반복문: 조건이 정확하게 설정되지 않아서 무한 루프에 빠지거나, 반복문이 의도했던 횟수보다 더 실행될 수 있습니다.

  4. 자료형 문제: 변수의 자료형이 클 때 정확하게 대응하지 못해 발생할 수 있는 문제가 없도록 주의하세요.

  5. 출력 형식 및 디테일: 문제의 요구 사항에 따라 출력 형식이 기대한 것과 다를 경우에도 틀릴 수 있습니다.

관련 내용을 더 참고하고 싶으시다면 아래 질문이 도움이 될 수 있습니다:
- 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