获取方向键的功能:使用getch.h头文件中的getch函数
1、把windows中的getch.h头文件放到共享文件夹中
2、终端输入 cd /media/sf_GONGXIANG进入共享文件夹
3、sudo cp getch.h /usr/include
4、cd /usr/include/
5、sudo chmod +r getch.h头文件中的getch函数
time.h time(NULL):获取1970-1-1 00:00:00到目前为止过了多少秒
走迷宫(不使用自定义函数)
1、定义一个字符型的二维数组作为迷宫图案
2、定义变量记录老鼠的位置
3、获取游戏开始时间
4、进入死循环1、清理屏幕2、显示地图(遍历二维数组)3、判断是否到达出口是:获取游戏结束时间,计算一共花了多少时间程序结束4、获取方向键并处理
#include<stdio.h>
#include<getch.h>
#include<time.h>int main(int argc,const char* argv[])
{char maze[10][10]={{'#','#','#',' ','#','#','#','#','#','#'}, {'#','@','#',' ',' ','#',' ',' ',' ','#'}, {'#',' ','#','#',' ','#',' ','#',' ','#'}, {'#',' ','#',' ',' ','#',' ','#',' ','#'}, {'#',' ','#',' ','#','#',' ','#',' ','#'}, {'#',' ','#',' ',' ',' ',' ','#',' ','#'}, {'#',' ','#','#','#','#','#','#',' ','#'}, {'#',' ','#',' ',' ',' ','#','#',' ','#'}, {'#',' ',' ',' ','#',' ',' ',' ',' ','#'}, {'#','#','#','#','#','#','#','#','#','#'}, };//出口0.3//定义变量老鼠的位置int m_x=1,m_y=1;//获取游戏开始时间time_t start=time(NULL);while(1){//清屏system("clear");//显示地图for(int i=0;i<10;i++){for(int j=0;j<10;j++){printf("%c ",maze[i][j]); }printf("\n");}if(m_x==0 && m_y==3){time_t end=time(NULL);printf("用时%d秒",-start+end);return 0;}//获取方向兼并处理switch(getch()){case 183:if(maze[m_x-1][m_y]==' '){maze[m_x-1][m_y]='@';maze[m_x][m_y]=' ';m_x--;}break;case 184:if(maze[m_x+1][m_y]==' '){maze[m_x+1][m_y]='@';maze[m_x][m_y]=' ';m_x++;}break;case 186:if(maze[m_x][m_y-1]==' '){maze[m_x][m_y-1]='@';maze[m_x][m_y]=' ';m_y--;}break;case 185:if(maze[m_x][m_y+1]==' '){maze[m_x][m_y+1]='@';maze[m_x][m_y]=' ';m_y++;}break;}}
}
推箱子(不使用自定义函数)
1、确定数字与字符的关系0 路 1 墙 #2 人 &3 箱 @4 终 o6 人+终 显示人7 箱+终 显示箱2、定义并初始化整形地图
char map[8][8]=
{{0,0,1,1,1,1,0,0},{0,0,1,4,4,1,0,0},{0,1,1,0,4,1,1,0},{0,1,0,0,3,4,1,0},{1,1,0,3,0,0,1,1},{1,0,0,1,3,3,0,1},{1,0,0,2,0,0,0,1},{1,1,1,1,1,1,1,1},
}
3、定义记录小人位置的坐标 6.3
4、进入死循环 1、清理屏幕2、显示地图(遍历二维数组)3、检查是否完成任务查7的个数完成显示步数,结束程序4、获取方向键并处理1、前面墙(不考虑)2、路或目标点参考迷宫3、箱子箱子前是路或目标点,推箱子前是墙,不动
#include<stdio.h>
#include<getch.h>
#include<stdlib.h>
int main(int argc,const char* argv[])
{int map[8][8]= {{0,1,1,1,1,0,0,0},{0,1,2,0,1,1,1,0},{0,1,0,3,0,0,1,0},{1,1,1,0,1,0,1,1},{1,4,1,0,1,0,0,1},{1,4,0,3,0,1,0,1},{1,4,0,0,3,0,0,1},{1,1,1,1,1,1,1,1},};int rx=1,ry=2;int step=0;while(1){int num7=0;system("clear");for(int i=0;i<8;i++){for(int j=0;j<8;j++){switch(map[i][j]){case 0:printf(" ");break;case 1:printf("# ");break;case 2:printf("& ");break;case 3:printf("@ ");break;case 4:printf("o ");break;case 6:printf("& ");break;case 7:printf("@ ");num7++;break;}}printf("\n");}if(3==num7){printf("步数=%d",step);return 0;}switch(getch()){case 183://upif(map[rx-1][ry]==0 || map[rx-1][ry]==4){map[rx][ry] -= 2;map[rx-1][ry] += 2;rx--;step++;}else if(map[rx-1][ry]==3 || map[rx-1][ry]==7){if(map[rx-2][ry]==0 || map[rx-2][ry]==4){map[rx-2][ry] += 3;map[rx-1][ry] -= 1;map[rx][ry] -= 2;rx--; step++;}}break; case 184://downif(map[rx+1][ry]==0 || map[rx+1][ry]==4){map[rx][ry] -= 2;map[rx+1][ry] += 2;rx++;step++;}else if(map[rx+1][ry]==3 || map[rx+1][ry]==7){if(map[rx+2][ry]==0 || map[rx+2][ry]==4){map[rx+2][ry] += 3;map[rx+1][ry] -= 1;map[rx][ry] -= 2;rx++; step++;}}break; case 186://leftif(map[rx][ry-1]==0 || map[rx][ry-1]==4){map[rx][ry] -= 2;map[rx][ry-1] += 2;ry--;step++;}else if(map[rx][ry-1]==3 || map[rx][ry-1]==7){if(map[rx][ry-2]==0 || map[rx][ry-2]==4){map[rx][ry-2] += 3;map[rx][ry-1] -= 1;map[rx][ry] -= 2;ry--; step++;}}break; case 185://rightif(map[rx][ry+1]==0 || map[rx][ry+1]==4){map[rx][ry] -= 2;map[rx][ry+1] += 2;ry++;step++;}else if(map[rx][ry+1]==3 || map[rx][ry+1]==7){if(map[rx][ry+2]==0 || map[rx][ry+2]==4){map[rx][ry+2] += 3;map[rx][ry+1] -= 1;map[rx][ry] -= 2;ry++;step++;}}break; }}
}
下面是提取重复部分后的代码
#include<stdio.h>
#include<getch.h>
#include<stdlib.h>
int main(int argc,const char* argv[])
{int map[8][8]= {{0,1,1,1,1,0,0,0},{0,1,2,0,1,1,1,0},{0,1,0,3,0,0,1,0},{1,1,1,0,1,0,1,1},{1,4,1,0,1,0,0,1},{1,4,0,3,0,1,0,1},{1,4,0,0,3,0,0,1},{1,1,1,1,1,1,1,1},};int rx=1,ry=2;int step=0;while(1){int num7=0;system("clear");for(int i=0;i<8;i++){for(int j=0;j<8;j++){switch(map[i][j]){case 0:printf(" ");break;case 1:printf("# ");break;case 2:printf("& ");break;case 3:printf("@ ");break;case 4:printf("o ");break;case 6:printf("& ");break;case 7:printf("@ ");num7++;break;}}printf("\n");}if(3==num7){printf("步数=%d",step);return 0;}//偏移int ox=0,oy=0;switch(getch()){case 183:ox--;break;//upcase 184:ox++;break;//downcase 186:oy--;break;//leftcase 185:oy++;break;//right }if(map[rx+ox][ry+oy]==0 || map[rx+ox][ry+oy]==4){map[rx][ry] -= 2;map[rx+ox][ry+oy] += 2;rx +=ox;ry +=oy;step++;}else if(map[rx+ox][ry+oy]==3 || map[rx+ox][ry+oy]==7){if(map[rx+ox+ox][ry+oy+oy]==0 || map[rx+ox+ox][ry+oy+oy]==4){map[rx+ox+ox][ry+oy+oy] += 3;map[rx+ox][ry+oy] -= 1;map[rx][ry] -= 2;rx +=ox;ry +=oy; step++;}}}
}