贪吃蛇C语言代码实现(难度可选)
2019/7/10 22:36:59
本文主要是介绍贪吃蛇C语言代码实现(难度可选),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
本文实例为大家分享了C语言实现贪吃蛇的具体代码,供大家参考,具体内容如下
/********************************************************* ********************贪吃蛇(难度可选)******************** **************制作者:Xu Lizi 日期:2012/12/31******** ********************部分函数有借鉴************************ **********************************************************/ #include<stdio.h> #include<conio.h> #include<string.h> #include<stdlib.h> #include<time.h> int snakey[100]={5,4,3,2,1}; /*定义蛇的横坐标*/ int snakex[100]={1,1,1,1,1}; /*定义蛇的纵坐标,蛇头起始位置为(5,1)*/ int life=0; /*定义蛇的生命,0表示存活,1表示死亡*/ int lenght=5; /*定义蛇的长度,初始为5节*/ char map[12][24]={"***********************", /*y*/ "* *", "* *", "* *", "* *", "* *", "* *", "* *", "* *", "* *", "* *", /*x*/ "***********************"}; void put_money(int i,int j) /*放钱函数,使用随机数,随机出现食物*/ { int x=0,y=0; srand(time(NULL)); while ( (map[y][x]==003) || (map[y][x]==002) || (map[y][x]=='*') || ((x==i)&&(y==j)) ) { x=rand()%21+1; y=rand()%10+1; } map[y][x]='$'; return; } void output() /*输出*/ { system("cls"); int i,j; for(i=0; i<12; i++) { for(j=0; j<23; j++) printf("%c", map[i][j]); printf("\n"); } return; } void gameover() /*游戏结束*/ { life=1; printf("笨蛋,输了吧!!!\n"); return; } void turn_up() /*向上移动*/ { system("cls"); int i; if ( (snakex[0]==1) || (map[snakex[0]-1][snakey[0]]==003) ) gameover(); else { if (map[snakex[0]-1][snakey[0]]=='$') { put_money( snakey[0], snakex[0]-1 ); lenght++; map[snakex[lenght-1]][snakey[lenght-1]]=003; } for(i=lenght; i>0; i--) { snakex[i]=snakex[i-1]; snakey[i]=snakey[i-1]; } map[snakex[lenght]][snakey[lenght]]=' '; snakex[0]--; for(i=lenght-1; i>0; i--) map[snakex[i]][snakey[i]]=003; map[snakex[0]][snakey[0]]=002; output(); } return; } void turn_down() /*向下*/ { system("cls"); int i; if ( (snakex[0]==10) || (map[snakex[0]+1][snakey[0]]==003) ) gameover();else { if (map[snakex[0]+1][snakey[0]]=='$') { put_money(snakey[0],snakex[0]+1); lenght++; map[snakex[lenght-1]][snakey[lenght-1]]=003; } for(i=lenght; i>0; i--) { snakex[i]=snakex[i-1]; snakey[i]=snakey[i-1]; } snakex[0]++; map[snakex[lenght]][snakey[lenght]]=' '; for(i=lenght-1; i>0; i--) map[snakex[i]][snakey[i]]=003; map[snakex[0]][snakey[0]]=002; output(); } return; } void turn_left() /*向左*/ { system("cls"); int i; if ( (snakey[0]==1) || (map[snakex[0]][snakey[0]-1]==003) ) gameover();else { if (map[snakex[0]][snakey[0]-1]=='$') { put_money(snakey[0]-1,snakex[0]); lenght++; map[snakex[lenght-1]][snakey[lenght-1]]=003; } for(i=lenght; i>0; i--) { snakex[i]=snakex[i-1]; snakey[i]=snakey[i-1]; } map[snakex[lenght]][snakey[lenght]]=' '; snakey[0]--; for(i=lenght-1; i>0; i--) map[snakex[i]][snakey[i]]=003; map[snakex[0]][snakey[0]]=002; output(); } return; } void turn_right() /*向右*/ { system("cls"); int i; if ( (snakey[0]==21) || (map[snakex[0]][snakey[0]+1]==003) ) gameover();else { if (map[snakex[0]][snakey[0]+1]=='$') { put_money(snakey[0]+1,snakex[0]); lenght++; map[snakex[lenght-1]][snakey[lenght-1]]=003; } for(i=lenght; i>0; i--) { snakex[i]=snakex[i-1]; snakey[i]=snakey[i-1]; } map[snakex[lenght]][snakey[lenght]]=' '; snakey[0]++; for(i=lenght-1; i>0; i--) map[snakex[i]][snakey[i]]=003; map[snakex[0]][snakey[0]]=002; output(); } return; } int main() { int i,timeover,hard; long start; char name , direcation; printf("\n 向上移动:W ;向下移动:S ; 向左移动:A ; 向右移动:D \n"); printf("\t请选择难度(数字)\n\t分1~5级,分别代表\n\t1难,2中上,3中,4中下5,易:\n"); scanf("%d",&hard); system("cls"); for(i=1;i<5;i++) map[1][i]=003; /*输出蛇身*/ map[1][5]=002; /*输出蛇头*/ put_money(0,0); output(); while(life!=1) /*当蛇死亡时结束循环*/ { /*让蛇自动运行的函数******有借鉴*/ timeover=1; start=clock(); while((timeover=(clock()-start<=hard*100))&&!kbhit()); //难度设定 if(timeover) { direcation=getch(); } /*让蛇自动运行的函数******有借鉴*/ switch(direcation) { case 'w':turn_up();break; case 's':turn_down();break; case 'a':turn_left();break; case 'd':turn_right();break; } } return 0; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持找一找教程网。
这篇关于贪吃蛇C语言代码实现(难度可选)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享