欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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語言16進制與ASCII字符相互轉(zhuǎn)換

    C語言16進制與ASCII字符相互轉(zhuǎn)換

    大家好,本篇文章主要講的是C語言16進制與ASCII字符相互轉(zhuǎn)換,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • C語言數(shù)組越界引發(fā)的死循環(huán)問題解決

    C語言數(shù)組越界引發(fā)的死循環(huán)問題解決

    本文主要介紹了C語言數(shù)組越界引發(fā)的死循環(huán)問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • C++LeetCode數(shù)據(jù)結(jié)構(gòu)基礎(chǔ)詳解

    C++LeetCode數(shù)據(jù)結(jié)構(gòu)基礎(chǔ)詳解

    這篇文章主要介紹了C++實現(xiàn)LeetCode數(shù)據(jù)結(jié)構(gòu),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • 純C語言:折半查找源碼分享

    純C語言:折半查找源碼分享

    這篇文章主要介紹了純C語言:折半查找源碼,有需要的朋友可以參考一下
    2014-01-01
  • 使用代碼驗證linux子進程與父進程的關(guān)系

    使用代碼驗證linux子進程與父進程的關(guān)系

    Linux下父進程可以使用fork 函數(shù)創(chuàng)建子進程,但是當父進程先退出后,子進程會不會也退出呢?通過下面這個小實驗,我們能夠很好的看出來
    2014-02-02
  • C++繼承與菱形繼承詳細介紹

    C++繼承與菱形繼承詳細介紹

    繼承(inheritance)機制是面向?qū)ο蟪绦蛟O(shè)計使代碼可以復用的最重要的手段,它允許程序員在保持原有類特性的基礎(chǔ)上進行擴展,增加功能,這樣產(chǎn)生新的類,稱派生類。繼承呈現(xiàn)了面向?qū)ο蟪绦蛟O(shè)計的層次結(jié)構(gòu),體現(xiàn)了由簡單到復雜的認知過程
    2022-08-08
  • C++ 數(shù)據(jù)結(jié)構(gòu)線性表-數(shù)組實現(xiàn)

    C++ 數(shù)據(jù)結(jié)構(gòu)線性表-數(shù)組實現(xiàn)

    這篇文章主要介紹了C++ 數(shù)據(jù)結(jié)構(gòu)線性表-數(shù)組實現(xiàn)的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • C語言基礎(chǔ)函數(shù)用法示例詳細解析

    C語言基礎(chǔ)函數(shù)用法示例詳細解析

    最接地氣的C函數(shù)基礎(chǔ)介紹,此處對于函數(shù)的相關(guān)知識點做一些簡要的介紹,作者實屬初學,寫博客也是作者學習的一個過程,難免文章中有內(nèi)容理解不到位或者有不當之處,還請朋友們不吝指正
    2021-11-11
  • 完美解決QT?QGraphicsView提升到QChartView報錯的問題

    完美解決QT?QGraphicsView提升到QChartView報錯的問題

    使用QT提供的QChartView來繪制圖表,提升QGraphicsView控件繼承QChartView后,然后將QGraphicsView提升到我們自己寫的類,怎么才能確保提升后編譯不報錯呢,下面小編給大家?guī)砹薗T QGraphicsView 提升到QChartView報錯解決方案,感興趣的朋友一起看看吧
    2023-05-05
  • C語言學習筆記之字符串間的那些事

    C語言學習筆記之字符串間的那些事

    字符串是C語言中最重要的數(shù)據(jù)類型之一,最近借助《C Primer Plus》一書來學習C中的常用字符串操作,在此作為筆記記錄,下面這篇文章主要給大家介紹了C語言學習筆記之字符串間的那些事,需要的朋友可以參考下
    2022-04-04

最新評論