Turbo-C
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
터보-C 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
Lua 게시판
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C/C++ Q/A
[2000] 아래 미로찾기 소스 추가 질문인데요...
로터스 [lotus11] 1340 읽음    2003-02-19 01:40
int  get_shape(int m[][MAZE_SIZE], int x, int y)
    {
    static shape[] =
        {  32, 179, 196, 192, 179, 179, 218, 195, 196, 217, 196,
          193, 191, 180, 194, 197 };
    int s = 0;
    if (m[y][x])
        {
        if (y > 0  &&  m[y-1][x]) s |= UP;
        if (y < MAZE_SIZE - 2  &&  m[y+1][x]) s |= DOWN;
        if (x > 0  &&  m[y][x-1]) s |= LEFT;
        if (x < MAZE_SIZE - 2  &&  m[y][x+1]) s |= RIGHT;
        }
    return shape[s];
    }

여기서요..

if (y < MAZE_SIZE - 2  &&  m[y+1][x]) s |= DOWN;

이부분 말인데요,

y < MAZE_SIZE - 2

이것 역할이 아랫쪽 경계를 넘지 않나 확인하는 거잖아요?
근데 왜 - 2 가 되는지 잘 모르겠네요..
- 1 이어야 할 것 같은데요..

전체 배열 크기가 m[19][19] 이고, y 값이 17이라고 한다면
17 < 17 이 되서 18행은 계산되지 않게 되는거 아닌가요? 19행이 경계인데....
아무쪼록 도움 부탁드립니다...

+ -

관련 글 리스트
2000 아래 미로찾기 소스 추가 질문인데요... 로터스 1340 2003/02/19
2013     Re:아래 미로찾기 소스 추가 질문인데요... pd 1373 2003/02/23
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.