C語言實現(xiàn)簡單推箱子小游戲
更新時間:2022年07月22日 08:41:45 作者:cdjccio
這篇文章主要為大家詳細介紹了C語言實現(xiàn)推箱子小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了C語言實現(xiàn)推箱子游戲的具體代碼,供大家參考,具體內(nèi)容如下
#include<stdio.h> #include<string.h> #include<stdlib.h> #define N 1000 /* r目的地 o箱子 i人 x墻 路(空格) w上 a左 d右 s下 */ void menu(); int level1(); int level2(); void swap(char*,char*); int opera(char *p,int *ren,int xzs); void dituprint(); void menu() { printf("推箱子\n"); printf("1.新游戲 2.選關(guān)\n"); printf("0.退出\n"); } void xuanguan() { int choice_level; while(1) { printf("請選擇關(guān)卡:\n"); scanf("%d",&choice_level); switch(choice_level) { case 1: level1(); break; case 2: level2(); break; default: printf("輸入錯誤,請重新選擇關(guān)卡!"); } } } void swap(char *a,char *b) { char ch; ch=*a; *a=*b; *b=ch; } void dituprint(char *p) { for(int i=0;i<9;i++) { for(int j=0;j<9;j++) printf("%3c",p[i*9+j]); printf("\n"); } } int opera(char *p,int *ren,int xzs) { dituprint(p); while(1) { for(int i=1,panduan=0;i<=xzs;i++) { if(p[ren[i]]=='o') { panduan+=1; printf("panduan=%d\n",panduan); } if(panduan==xzs) { printf("恭喜你,過關(guān)啦!"); getchar(); return 0; } } char ch; printf("你的按鍵是:"); scanf("%c",&ch); switch(ch) { case 'w': { if(p[ren[0]]=='r') { if(p[ren[0]-9]=='r') { ren[0]-=9; p[ren[0]='i']; p[ren[0]+9]='r'; break; } if(p[ren[0]-9]=='x') { printf("人碰到墻了 換按其他鍵1哇>>>>>"); break; } if(p[ren[0]-9]==' ') { ren[0]-=9; p[ren[0]='i']; p[ren[0]-9]='r'; break; } if(p[ren[0]-9]=='o') { if(p[ren[0]-18]=='x'||'o') printf("箱子碰到了 換按其他鍵1哇>>>>>");break; if(p[ren[0]-18]=='r') { p[ren[0]-18]='o'; p[ren[0]-9]='i'; p[ren[0]]='r'; ren[0]-=9; break; } if(p[ren[0]-18]=='o') printf("推不動誒 換按其他鍵1哇>>>>>");break; if(p[ren[0]-18]==' ') { swap(&p[ren[0]-9],&p[ren[0]-18]); swap(&p[ren[0]],&p[ren[0]-9]); p[ren[0]]='r'; ren[0]-=9; break; } } } else { if(p[ren[0]-9]=='x') { printf("人碰到墻了 換按其他鍵2>>>>>"); break; } if(p[ren[0]-9]==' ') { swap(&p[ren[0]],&p[ren[0]-9]); ren[0]-=9; break; } if(p[ren[0]-9]=='o') { if(p[ren[0]-18]=='o'||p[ren[0]-18]=='x') { printf("走不動了 換按其他鍵哇。。。。\n"); break; } if(p[ren[0]-18]=='r') { p[ren[0]-18]='o'; p[ren[0]-9]='i'; p[ren[0]]=' '; ren[0]-=9; break; } } } } break; case 'a': { if(p[ren[0]]=='r') { if(p[ren[0]-1]=='r') { ren[0]-=1; p[ren[0]]='i'; p[ren[0]+1]='r'; break; } if(p[ren[0]-1]=='x') { printf("人碰到墻了 換按其他鍵1哇>>>>>"); break; } if(p[ren[0]-1]==' ') { ren[0]-=1; p[ren[0]]='i'; p[ren[0]+9]='r'; break; } if(p[ren[0]-1]=='o') { if(p[ren[0]-2]=='o'||p[ren[0]-2]=='x') { printf("走不動了 換按其他鍵娃娃。。。。。\n"); break; } if(p[ren[0]-2]=='r') { p[ren[0]-2]='o'; p[ren[0]-1]='i'; p[ren[0]]=' '; ren[0]-=1; break; } if(p[ren[0]-2]==' ') { p[ren[0]-2]='o'; p[ren[0]-1]='i'; p[ren[0]]=' '; ren[0]-=1; break; } } } } break; case 's': { if(p[ren[0]]=='r') { if(p[ren[0]+9]=='r') { ren[0]+=9; p[ren[0]]='i'; p[ren[0]-9]='r'; break; } if(p[ren[0]+9]=='x') { printf("人碰到墻了 換按其他鍵1哇>>>>>"); break; } if(p[ren[0]+9]==' ') { ren[0]+=9; p[ren[0]]='i'; p[ren[0]+9]='r'; break; } if(p[ren[0]+9]=='o') { if(p[ren[0]+18]=='x'||'o') { printf("箱子碰到墻了 換按其他鍵1哇>>>>>");break; if(p[ren[0]+18]=='r') { p[ren[0]+18]='o'; p[ren[0]+9]='i'; p[ren[0]]='r'; ren[0]+=9; break; } if(p[ren[0]+18]=='o') printf("推不動哎 換按其他鍵1哇>>>>>");break; if(p[ren[0]+18]==' ') { swap(&p[ren[0]+9],&p[ren[0]+18]); swap(&p[ren[0]],&p[ren[0]-9]); p[ren[0]]='r'; ren[0]+=9; break; } } } else { if(p[ren[0]+9]=='x') { printf("人碰到墻了,換按其他鍵哇2>>>>>"); break; } if(p[ren[0]+9]==' ') { swap(&p[ren[0]],&p[ren[0]+9]); ren[0]+=9; break; } if(p[ren[0]+9]=='o') { if(p[ren[0]+18]=='o'||p[ren[0]+18]=='x') { printf("走不動了,換按其他鍵哇。。。。。\n"); break; } if(p[ren[0]+18]=='r') { p[ren[0]+18]='o'; p[ren[0]+9]='i'; p[ren[0]]=' '; ren[0]+=9; break; } if(p[ren[0]+18]==' ') { p[ren[0]+18]='o'; p[ren[0]+9]='i'; p[ren[0]]=' '; ren[0]+=9; break; } } } } break; case'd': { if(p[ren[0]]=='r') { if(p[ren[0]+1]=='r') { ren[0]+=1; p[ren[0]]='i'; p[ren[0]-1]='r'; break; } if(p[ren[0]+1]=='x') { printf("人碰到墻了 換按其他鍵1哇>>>>>"); break; } if(p[ren[0]+1]==' ') { ren[0]+=1; p[ren[0]]='i'; p[ren[0]-1]='r'; break; } if(p[ren[0]+1]=='o') { if(p[ren[0]+2]=='x'||'o') printf("箱子碰到墻了 換按其他鍵1哇>>>>>>"); break; if(p[ren[0]+2]=='r') { p[ren[0]+2]='o'; p[ren[0]+1]='i'; p[ren[0]]='r'; p[0]+=1; break; } if(p[ren[0]+2]=='o') printf("推不動誒 換按其他鍵1哇>>>>>");break; if(p[ren[0]+2]==' ') { swap(&p[ren[0]+1],&p[ren[0]+2]); swap(&p[ren[0]],&p[ren[0]-1]); p[ren[0]]='r'; ren[0]+=1; break; } } } else { if(p[ren[0]+1]=='x') { printf("人碰到墻了,換按其他鍵哇2>>>>>"); break; } if(p[ren[0]+1]==' ') { swap(&p[ren[0]],&p[ren[0]+1]); ren[0]+=1; break; } if(p[ren[0]+1]=='o') { if(p[ren[0]+2]=='o'||p[ren[0]+2]=='x') { printf("走不動了!換按其他鍵哇。。。。。"); break; } if(p[ren[0]+2]=='r') { p[ren[0]+2]='o'; p[ren[0]+1]='i'; p[ren[0]]=' '; ren[0]+=1; break; } if(p[ren[0]+2]==' ') { p[ren[0]+2]='o'; p[ren[0]+1]='i'; p[ren[0]]=' '; ren[0]+=1; break; } } } } break; default:printf("操作錯誤!請確認后再重新操作。。。。。"); } dituprint(p); } /*int panduan=0; for(int i=1;i<xzs;i++) { if(p[ren[0]]=='o')panduan++; } if(panduan=(xzs-1)){getchar();break;}*/ } return 0; } int level1() { printf("第一關(guān)\n"); char ditu1[9*9]={ '0','1','2','3','4','5','6','7','8', '1',' ',' ','x','x','x',' ',' ',' ', '2',' ',' ','x','r','x',' ',' ',' ', '3',' ',' ','x',' ','x','x','x','x', '4','x','x','x','o','x','o','r','x', '5','x','r',' ','o','i','x','x','x', '6','x','x','x','x','o','x',' ',' ', '7',' ',' ',' ','x','r','x',' ',' ', '8',' ',' ',' ','x','x','x',' ',' ', }; int ren1[5]={50,22,47,43,68}; opera(ditu1,ren1,4); level2(); return 0; } int level2() { printf("歡迎來到第二關(guān)\n"); char ditu1[9*9]={ '0','1','2','3','4','5','6','7','8', '1',' ',' ','x','x','x',' ',' ',' ', '2',' ',' ','x','r','x',' ',' ',' ', '3',' ',' ','x',' ','x','x','x','x', '4','x','x','x','o','x','o','r','x', '5','x','r',' ','o','i','x','x','x', '6','x','x','x','x','o','x',' ',' ', '7',' ',' ',' ','x','r','x',' ',' ', '8',' ',' ',' ','x','x','x',' ',' ', }; int ren1[5]={50,22,47,43,68}; opera(ditu1,ren1,4); level1(); return 0; } int main() { int choice; menu(); while(1) { scanf("%d",&choice); switch(choice) { case 0: exit(0); case 1: { level1(); break; } case 2: { xuanguan(); break; } default: { printf("操作錯誤!請確認正確后操作。。。。。\n"); } } } getchar(); return 0; }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語言數(shù)組越界引發(fā)的死循環(huán)問題解決
本文主要介紹了C語言數(shù)組越界引發(fā)的死循環(huán)問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-08-08C++LeetCode數(shù)據(jù)結(jié)構(gòu)基礎(chǔ)詳解
這篇文章主要介紹了C++實現(xiàn)LeetCode數(shù)據(jù)結(jié)構(gòu),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-08-08C++ 數(shù)據(jù)結(jié)構(gòu)線性表-數(shù)組實現(xiàn)
這篇文章主要介紹了C++ 數(shù)據(jù)結(jié)構(gòu)線性表-數(shù)組實現(xiàn)的相關(guān)資料,需要的朋友可以參考下2017-06-06完美解決QT?QGraphicsView提升到QChartView報錯的問題
使用QT提供的QChartView來繪制圖表,提升QGraphicsView控件繼承QChartView后,然后將QGraphicsView提升到我們自己寫的類,怎么才能確保提升后編譯不報錯呢,下面小編給大家?guī)砹薗T QGraphicsView 提升到QChartView報錯解決方案,感興趣的朋友一起看看吧2023-05-05