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

C/C++ Q/A
[1998] Re:이 부분 해석 좀 부탁드려요..
미로찾기 소스인거 같 [] 1133 읽음    2003-02-18 23:41
로터스 님이 쓰신 글 :
: 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 구문이 무슨 뜻인지 모르겠네요...
:
:         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;
:
: 이거 네개 해석해주시면 고맙겠습니다.
: 아주 초짜는 아닌데 헤깔리네요...;

if (y > 0  &&  m[y-1][x]) s |= UP;
-> 풀어쓰면.. y가 0보다 크고 m[y-1][x]가 0이 아니면 s = s | UP입니다.
  y를 확인해보는 이유는 y-1이 음수가 나오면 안되니까 그런거구요..
  m[y-1][x]에 저장된 값이 0이 아니면 true가 되죠.. 그러면
  s는 현재 저장된 s값과 UP(미리 정해진 값이겠죠)을 | (비트연산 or란거 아시죠)연산
  해서 다시 저장하는거죠..

if (y < MAZE_SIZE - 2  &&  m[y+1][x]) s |= DOWN;
-> 이것역시 최대 배열사이즈를 확인하기위해 y를 비교하고 값에 따라서 비트연산을하죠
   이하 x값 처리도 마찬가지인거죠.. 그래서 전후좌우 방향을 체크하는 것 같네요...
   이상 저의 생각입니다..

+ -

관련 글 리스트
3863         Re:Re:이 부분 해석 좀 부탁드려요.. 로터스 1134 2003/02/19
1998     Re:이 부분 해석 좀 부탁드려요.. 미로찾기 소스인거 같 1133 2003/02/18
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.