inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2-D

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

311

0508gyhun

작성한 질문수 10

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가 어느순서로 들어가는지 사고과정을 좀 알려주시면 감사하겠습니다.

}

}

 

 

c++ 코딩-테스트

답변 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점은 제가 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

코딩 살구 클럽 컴파일 에러

0

4

1

추천 문제

0

7

1

코딩살구클럽 승인

0

9

1

코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의

0

21

2

문제를 고민하는 시간 관련

0

26

2

코딩살구클럽

0

38

2

코딩살구클럽 문의

0

37

2

코딩살구클럽 승인

0

35

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

33

2

3-F 채점 관련 질문

0

31

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

33

2

코딩살구클럽 승인

0

45

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

54

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

45

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

56

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

63

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

67

2

코딩살구클럽 로그인문제

0

85

3

코딩 살구 클럽 로그인 문제

0

86

2