用C語言編寫推箱子游戲
更新時間:2019年10月21日 14:50:45 作者:Pastthewind
這篇文章主要為大家詳細介紹了用C語言編寫推箱子游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了C語言推箱子游戲的具體實現(xiàn)代碼,供大家參考,具體內(nèi)容如下
#include <stdio.h>
#include <stdlib.h>
#include<string.h>
#include <conio.h>
//行和列
#define ROW 10
#define COL 11
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
/**
*
*
*/
//地圖
char map[ROW][COL] = {
"##########",//0
"### ##",//1
"### ##",//2
"##AX # ##",//3
"### ## ",//4
"##### #",//5
"## #",//6
"# ####",//7
"### ",//8
"##########" //9
//A:人 , X:箱子
} ;
//打印地圖
void showMap();
//接收小人的方向
char enterDirection();
//小人向上移動的方法
void moveToUp();
//小人向下移動的方法
void moveToDown();
//小人向右移動的方法
void moveToRight();
//小人向左移動的方法
void moveToLeft();
//當前小人的坐標
int currentPersonRow = 3;
int currentPersonCol = 2;
//當前箱子的坐標
int currentBoxRow = 3;
int currentBoxCol = 3;
int main(int argc, char *argv[]) {
//system("clear");
printf("點擊回車鍵開始游戲 ^_^\n\n");
//1代表運行 0停止
int flag = 1;
while(flag==1){
//顯示地圖
showMap();
//接收小人的方向
char dir = enterDirection();
switch(dir){
//小人向上移動
case 'w':
case 'W':
moveToUp();
break;
//小人向下移動
case 's':
case 'S':
moveToDown();
break;
//小人向右移動
case 'd':
case 'D':
moveToRight();
break;
//小人向左移動
case 'a':
case 'A':
moveToLeft();
break;
//停止運行
case 'q':
case 'Q':
printf("你的智商真低!T_T\n");
flag = 0;
break;
}
showMap();
if(currentBoxRow==8&¤tBoxCol==9){
printf("你的智商真高^_^!!!");
flag = 0;
}
}
}
/*
方法的實現(xiàn)
*/
//打印地圖
void showMap(){
int i;
for(i = 0;i < ROW; i++){
printf("%s\n",map[i]);
}
printf("\n\n\n\n\n");
printf("W:上,S:下, A:左, D:右。Q:退出");
printf("\n\n\n\n\n");
}
//接收小人的方向
char enterDirection(){
//清除SCANF中的緩沖區(qū)
rewind(stdin);
char dir;
dir = getch();
//scanf("%c",&dir);
return dir;
}
//小人向上移動的方法
void moveToUp(){
//小人的下一個坐標
int nextPersonCol = currentPersonCol;
int nextPersonRow = currentPersonRow - 1;
//箱子的下一個坐標
int nextBoxRow = currentBoxRow - 1;
int nextBoxCol = currentBoxCol;
//如果小人的下一個坐標是路
if(map[nextPersonRow][nextPersonCol]==' '){
map[nextPersonRow][nextPersonCol] = 'A';
map[currentPersonRow][currentPersonCol] = ' ';
currentPersonRow = nextPersonRow;
currentPersonCol = nextPersonCol;
}
//如果小人的下一個坐標是墻
if(map[nextPersonRow][nextPersonCol]=='#'){
//什么也不做
}
//如果小人的下一個坐標是箱子
if(map[nextPersonRow][nextPersonCol]=='X'){
if(map[nextBoxRow][nextBoxCol] == ' '){
map[nextPersonRow][nextPersonCol] = 'A';
map[currentPersonRow][currentPersonCol] = ' ';
map[nextBoxRow][nextBoxCol] = 'X';
map[currentBoxRow][currentBoxCol] = 'A';
currentPersonRow = nextPersonRow;
currentPersonCol = nextPersonCol;
currentBoxRow = nextBoxRow;
currentBoxCol = nextBoxCol;
}
}
}
//小人向下移動的方法
void moveToDown(){
//小人的下一個坐標
int nextPersonCol = currentPersonCol;
int nextPersonRow = currentPersonRow + 1;
//箱子的下一個坐標
int nextBoxRow = currentBoxRow + 1;
int nextBoxCol = currentBoxCol;
//如果小人的下一個坐標是路
if(map[nextPersonRow][nextPersonCol]==' '){
map[nextPersonRow][nextPersonCol] = 'A';
map[currentPersonRow][currentPersonCol] = ' ';
currentPersonRow = nextPersonRow;
currentPersonCol = nextPersonCol;
}
//如果小人的下一個坐標是墻
if(map[nextPersonRow][nextPersonCol]=='#'){
//什么也不做
}
//如果小人的下一個坐標是箱子
if(map[nextPersonRow][nextPersonCol]=='X'){
if(map[nextBoxRow][nextBoxCol] == ' '){
map[nextPersonRow][nextPersonCol] = 'A';
map[currentPersonRow][currentPersonCol] = ' ';
map[nextBoxRow][nextBoxCol] = 'X';
map[currentBoxRow][currentBoxCol] = 'A';
currentPersonRow = nextPersonRow;
currentPersonCol = nextPersonCol;
currentBoxRow = nextBoxRow;
currentBoxCol = nextBoxCol;
}
}
}
//小人向右移動的方法
void moveToRight(){
//小人的下一個坐標
int nextPersonCol = currentPersonCol + 1;
int nextPersonRow = currentPersonRow;
//箱子的下一個坐標
int nextBoxRow = currentBoxRow;
int nextBoxCol = currentBoxCol + 1;
//如果小人的下一個坐標是路
if(map[nextPersonRow][nextPersonCol]==' '){
map[nextPersonRow][nextPersonCol] = 'A';
map[currentPersonRow][currentPersonCol] = ' ';
currentPersonRow = nextPersonRow;
currentPersonCol = nextPersonCol;
}
//如果小人的下一個坐標是墻
if(map[nextPersonRow][nextPersonCol]=='#'){
//什么也不做
}
//如果小人的下一個坐標是箱子
if(map[nextPersonRow][nextPersonCol]=='X'){
if(map[nextBoxRow][nextBoxCol]==' '){
map[nextPersonRow][nextPersonCol] = 'A';
map[currentPersonRow][currentPersonCol] = ' ';
map[nextBoxRow][nextBoxCol] = 'X';
map[currentBoxRow][currentBoxCol] = 'A';
currentPersonRow = nextPersonRow;
currentPersonCol = nextPersonCol;
currentBoxRow = nextBoxRow;
currentBoxCol = nextBoxCol;
}
}
}
//小人向左移動的方法
void moveToLeft(){
//小人的下一個坐標
int nextPersonCol = currentPersonCol - 1;
int nextPersonRow = currentPersonRow;
//箱子的下一個坐標
int nextBoxRow = currentBoxRow;
int nextBoxCol = currentBoxCol - 1;
//如果小人的下一個坐標是路
if(map[nextPersonRow][nextPersonCol]==' '){
map[nextPersonRow][nextPersonCol] = 'A';
map[currentPersonRow][currentPersonCol] = ' ';
currentPersonRow = nextPersonRow;
currentPersonCol = nextPersonCol;
}
//如果小人的下一個坐標是墻
if(map[nextPersonRow][nextPersonCol]=='#'){
//什么也不做
}
//如果小人的下一個坐標是箱子
if(map[nextPersonRow][nextPersonCol]=='X'){
if(map[nextBoxRow][nextBoxCol]==' '){
map[nextPersonRow][nextPersonCol] = 'A';
map[currentPersonRow][currentPersonCol] = ' ';
map[nextBoxRow][nextBoxCol] = 'X';
map[currentBoxRow][currentBoxCol] = 'A';
currentPersonRow = nextPersonRow;
currentPersonCol = nextPersonCol;
currentBoxRow = nextBoxRow;
currentBoxCol = nextBoxCol;
}
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++算法學(xué)習(xí)之分支限界法的應(yīng)用
分支限界法常以廣度優(yōu)先或以最小耗費(最大效益)優(yōu)先的方式搜索問題的解空間樹。本文將詳細講解分支限界法的應(yīng)用,需要的可以參考一下2022-05-05
C語言 strftime 格式化顯示日期時間的實現(xiàn)
下面小編就為大家?guī)硪黄狢語言 strftime 格式化顯示日期時間的實現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-12-12
C++ 動態(tài)數(shù)組模版類Vector實例詳解
這篇文章主要為大家詳細介紹了C++動態(tài)數(shù)組模版類Vector實例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-02-02

