작성
·
239
0
cin >> m >> n >> k;
저는 이런식으로 큰돌님과 거꾸로 해서 풀었는데요.
fill(&a[0][0], &a[100][101], 1);
for (int i = 0; i < k; i++)
{
cin >> sx >> sy;
cin >> ex >> ey;
ey -= 1;
ex -= 1;
a[sy][sx] = 0; //2,0
a[ey][ex] = 0;// 3,3
for (int j = sy; j <= ey; j++)
{
for (int p = sx; p <= ex; p++)
{
a[j][p] = 0;
}
}
아래 큰돌님 소스가 더 간단한 것 같아서 이해를 하려고 하는데 머리에서 쥐가나네요..
for(int i = 0; i < k; i++){
cin >> x1 >> y1 >> x2 >> y2;
for(int x = x1; x < x2; x++){
for(int y = y1; y < y2; y++){
a[y][x] = 1;
}
}
0대신 1로 표기하는 것은 이해햇으나, 이중포문의 순서나 a[][] 에서 x,y가 어느순서로 들어가는지 사고과정을 좀 알려주시면 감사하겠습니다.
}
}
답변 1
0
안녕하세요 0508님 ㅎㅎ
아래의 코드를
for(int i = 0; i < k; i++){
cin >> x1 >> y1 >> x2 >> y2;
for(int x = x1; x < x2; x++){
for(int y = y1; y < y2; y++){
a[y][x] = 1;
}
}
}
이렇게 y부터, 그다음 x부터 ... 로 고쳤다는 말씀이시죠?
for (int j = sy; j <= ey; j++)
{
for (int p = sx; p <= ex; p++)
{
a[j][p] = 0;
}
}
이게 의미하는 바는 제꺼랑 똑같습니다. 다만 저랑은 다르게 1이 아니라 0으로 표기를 하신거구요.
그림으로 표기하면 다음과 같습니다. 0508님은 위쪽처럼, 저는 아래쪽 처럼 색을 칠한거에요.
그리고 다음에 질문하실 때는 0주차 - 질문하는 법 참고해서 올려주세요 ㅎㅎ
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제가 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.