인프런 커뮤니티 질문&답변

0508gyhun님의 프로필 이미지
0508gyhun

작성한 질문수

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

2-D

좌표를 2차원 배열로 나타낼때

작성

·

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님은 위쪽처럼, 저는 아래쪽 처럼 색을 칠한거에요.

image

 

그리고 다음에 질문하실 때는 0주차 - 질문하는 법 참고해서 올려주세요 ㅎㅎ

 

또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제가 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

0508gyhun님의 프로필 이미지
0508gyhun

작성한 질문수

질문하기