C언어 미로찾기 질문
카프리콘
질문 제목 : c언어 미로찾기 입니다.미로찾기를 하는도중 길목에 숫자를 생성해 차례대로 먹게끔 하도록 하는 프로그램질문 내용 :
#includestdio.h
#includeconio.h
#includewindows.h
#includetime.h
#define left 75
#define right 77
#define up 72
#define down 80 void gotoxy(int x, int y);
void setmap();
bool move(char ch); char startx = 0;
char starty = 0;
char endx = 0;
char endy = 0;
//1-13char map[20][25] =
{{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1},
{0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1},
{1,0,1,1,1,1,0,1,1,1,1,0,1,1,1,1,1,1,1,0,1,1,0,1,1},
{1,0,1,1,1,1,0,1,1,1,1,0,1,1,1,1,1,1,1,0,1,1,0,1,1},
{1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1},
{1,1,1,1,1,1,1,0,1,1,0,1,1,1,1,1,1,1,1,1,1,1,1,0,1},
{1,1,1,1,1,1,1,0,1,1,0,1,1,1,1,1,1,1,1,1,1,1,1,0,1},
{1,1,1,1,1,1,1,0,1,1,0,1,1,1,1,1,1,1,1,1,1,1,1,0,1},
{1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1},
{1,0,1,1,1,1,1,1,1,1,0,1,1,1,1,1,1,1,1,1,1,1,1,0,1},
{1,0,1,1,1,1,1,1,1,1,0,1,1,1,1,1,1,1,1,1,1,1,1,0,1},
{1,0,1,1,1,1,1,1,1,1,0,1,1,1,1,1,1,1,1,1,1,1,1,0,1},
{1,0,1,1,1,1,1,1,1,1,0,1,1,1,1,1,1,1,1,1,1,1,1,0,1},
{1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1},
{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,1,0,1,1,1,1},
{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,1,0,1,1,1,1},
{1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1},
{1,0,1,1,1,1,1,1,1,1,1,1,0,1,1,1,1,1,1,1,0,1,1,1,1},
{1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1}
};
void main()
{
setmap();
while(true)
{
if(move(getch()))
{
break;
}
}
while(getch() != 27)
{
gotoxy(0,26);
printf(clear\n종료는 esc\n);
}
}
bool move(char ch)
{
switch(ch)
{
case left:
if(map[starty][startx-1] != 1)
{
printf(□);
startx--;
break;
case right:
if(map[starty][startx+1] != 1)
{
printf(□);
startx++;
}
break;
case up:
if(map[starty-1][startx] != 1)
{
printf(□);
starty--;
}
break;
case down:
if(map[starty+1][startx] != 1)
{
printf(□);
starty++;
}
break;
}
gotoxy(startx*2,starty);
printf(◎);
gotoxy(startx*2,starty);
if(map[startx][starty] == map[endx][endy])
{
return true;
}
else
{
return false;
}
}void setmap()
{
char ch;
int q, p;
int z;
z = rand()%7; // 길을 랜덤으로 하여 숫자를 추가하려고 해논것
q = rand()%19;
p = rand()%24;
for(int i=0; isizeof(map) / sizeof(map[0]); i++)
{
for(int j=0; jsizeof(map[0]) / sizeof(map[0][0]); j++)
{
ch = map[i][j];
switch(ch)
{
case 0:
printf(□);
break;
case 1:
printf(■);
break;
case 2:
printf(◎);
startx = i;
starty = j;
break;
case 3 :
printf(★);
endx = i;
endy = j;
break;
}
} printf(\n);
}
gotoxy(startx*2, starty);
} void gotoxy(int x, int y)
{
coord position = {x, y};
setconsolecursorposition(getstdhandle(std_output_handle), position);
}
함수를 사용하여 화면을 깜박이지 않고 좌표를 구하여 이동하면서 미로를 찾게 하였습니다.
여기서 숫자를 길목에 랜덤으로 부여해서 그것을 먹으면서 전진하려 하는데
예를 들어 while(map[q][p] == 0)
{
{
if( z == 1)
printf(①);
else if(z == 2)
printf(②);/p②);
else if(z == 3)
printf(③);
else if(z == 4)
printf(④);
else if(z == 5)
printf(⑤);
else if(z == 6)
printf(⑥);
else if(z == 7)
printf(⑦);
}
문을 사용하여 넣으려하는데 미로에 신경쓰다보니이항목 추가가 안되더라고요 맵을 나타내주는 함수에 추가 하여 나면 에러가 납니다..조언 부탁드립니다 ㅜㅜ
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2695166 | do while 문 어떤것이잘못된건지 모르겠어요 (2) | 아이폰 | 2025-05-18 |
2695122 | 구조체에 대해 물어보고 싶은게 있습니다 ^^^.. (7) | 수련 | 2025-05-17 |
2695091 | txt 파일 입출력 후 2차 배열에 저장하기입니다. (3) | 헛장사 | 2025-05-17 |
2695063 | 수도요금 프로그램좀 짜주세요. | 시내 | 2025-05-17 |
2695033 | 답변좀요ㅠㅠ (1) | 비사벌 | 2025-05-16 |
2695010 | C++의 STL은 왜 굳이 템플릿화 시켜서 라이브러리를 만드나요? (초보수준의 질문..) (2) | 엘보어 | 2025-05-16 |
2694958 | 로직이 변한다는 것에 대해서 궁금합니다. | 튼동 | 2025-05-16 |
2694929 | 열혈강의 25-2 두번째 문제 질문 | 지우개 | 2025-05-15 |
2694900 | dequeue 에서 리턴값 프린트 방법알려주세요 오늘 12시까지 대화방에 있습니다 도와주세요 | 미투리 | 2025-05-15 |
2694854 | 절대값을 구할때 (2) | 그녀는귀여웠다 | 2025-05-15 |
2694827 | 이제 어떻게 공부해야할지 모르겠네요 | 새얀 | 2025-05-14 |
2694778 | 순열 계산요. | 맛조이 | 2025-05-14 |
2694754 | ShowWindow 함수를 이용하려 하는데 질문있습니다. (2) | 파도 | 2025-05-14 |
2694731 | 리눅스 커널의 시작점 질문 | 미르 | 2025-05-13 |
2694702 | 이거 뭐가문제인가요 코드수정좀 (3) | 맑은 | 2025-05-13 |
2694675 | C언어 후위표기를 중위표기로 | 앨런 | 2025-05-13 |
2694646 | 안녕하세요 파일 합치기 함수! (1) | 연블루 | 2025-05-13 |
2694618 | 잘몰라서 설명부탁드립니다. scanf 관련 (3) | 파라 | 2025-05-12 |
2694590 | 이 코드가 뭐하는 코드일까요? #2 | 빵순 | 2025-05-12 |
2694559 | 동적할당으로 배열(2차원열)을 만드는데 있어 그걸 함수화시키는데... (1) | 늘솔길 | 2025-05-12 |