C/C++編寫推箱子小遊戲
本文實例為大傢分享瞭C/C++編寫推箱子小遊戲的具體代碼,供大傢參考,具體內容如下
我們用’ #’來代表墻,‘O’來代表箱子,’ * ‘代表終點,‘@’代表箱子已經到達終點,‘S來表示人’。
註意:W,A,S,D為方向鍵,而且要在英文格式下
運行示例:
以下為完整代碼:
/* 推箱子(示例二) */ #include <stdio.h> #include <stdlib.h> #include <windows.h> #include <conio.h> int main() { char a[12][12]={"##########", "## ###", "##O### #", "# S O O #", "# **# O ##", "##**# ##", "##########", }; int x=3,y=2; int i; char ch; for(i=0;i<7;i++) puts(a[i]); while(a[4][2]!='@'||a[4][3]!='@'||a[5][2]!='@'||a[5][3]!='@') { ch=getch(); if(ch=='s') { if(a[x+1][y]!='#'&&a[x+1][y]!='O'&&a[x+1][y]!='@') //如果隻有人,沒有箱子 { a[x][y]=' '; x++; a[x][y]='S'; } else if(a[x+2][y]!='#'&&a[x+1][y]=='O'&&a[x+2][y]!='*') //如果是箱子和人一起走 { a[x][y]=' '; x++; a[x][y]='S'; a[x+1][y]='O'; } else if(a[x+2][y]!='#'&&(a[x+1][y]=='O'||a[x+1][y]=='@')&&a[x+2][y]=='*') //如果人和箱子一起走,並且前面是終點 { a[x][y]=' '; x++; a[x][y]='S'; a[x+1][y]='@'; } } if(ch=='w') { if(a[x-1][y]!='#'&&a[x-1][y]!='O'&&a[x-1][y]!='@') //如果隻有人,沒有箱子 { a[x][y]=' '; x--; a[x][y]='S'; } else if(a[x-2][y]!='#'&&a[x-1][y]=='O'&&a[x-2][y]!='O') //如果是箱子和人一起走 { a[x][y]=' '; x--; a[x][y]='S'; a[x-1][y]='O'; } else if(a[x-2][y]!='#'&&(a[x-1][y]=='O'||a[x-1][y]=='@')&&a[x-2][y]=='*') //如果人和箱子一起走,並且前面是終點 { a[x][y]=' '; x--; a[x][y]='S'; a[x-1][y]='@'; } } if(ch=='a') { if(a[x][y-1]!='#'&&a[x][y-1]!='O'&&a[x][y-1]!='@') //如果隻有人,沒有箱子 { a[x][y]=' '; y--; a[x][y]='S'; } else if(a[x][y-2]!='#'&&a[x][y-1]=='O') //如果是箱子和人一起走 { a[x][y]=' '; y--; a[x][y]='S'; a[x][y-1]='O'; } else if(a[x][y-2]!='#'&&(a[x][y-1]=='O'||a[x][y-1]=='@')&&a[x][y-2]=='*') //如果人和箱子一起走,並且前面是終點 { a[x][y]=' '; y--; a[x][y]='S'; a[x][y-1]='@'; } } if(ch=='d') { if(a[x][y+1]!='#'&&a[x][y+1]!='O'&&a[x][y+1]!='@') //如果隻有人,沒有箱子 { a[x][y]=' '; y++; a[x][y]='S'; } else if(a[x][y+2]!='#'&&a[x][y+1]=='O'&&a[x][y+2]!='O') //如果是箱子和人一起走 { a[x][y]=' '; y++; a[x][y]='S'; a[x][y+1]='O'; } else if(a[x][y+2]!='#'&&(a[x][y+1]=='O'||a[x][y+1]=='@')&&a[x][y+2]=='*'&&a[x][y+2]!='O') //如果人和箱子一起走,並且前面是終點 { a[x][y]=' '; y++; a[x][y]='S'; a[x][y+1]='@'; } } if(a[4][2]!='@'&&a[4][2]!='S'&&a[4][2]!='*') { a[4][2]='*'; } if(a[4][3]!='@'&&a[4][3]!='S'&&a[4][3]!='*') { a[4][3]='*'; } if(a[5][2]!='@'&&a[5][2]!='S'&&a[5][2]!='*') { a[5][2]='*'; } if(a[5][3]!='@'&&a[5][3]!='S'&&a[5][3]!='*') { a[5][3]='*'; } if(a[1][2]=='O'||a[1][6]=='O'||a[2][8]=='O'||a[3][8]=='O'||a[5][5]=='O'||a[5][7]=='O') //判斷失敗的情況 { break; } system("cls"); for(i=0;i<7;i++) puts(a[i]); } system("cls"); if(a[4][2]!='@'||a[4][3]!='@'||a[5][2]!='@'||a[5][3]!='@') printf("YOU LOSE!"); else printf("YOU WIN!"); Sleep(3000); return 0; }
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。