C语言实现简单推箱子小游戏

 更新时间:2022年07月22日 08:41:45   作者:cdjccio  
这篇文章主要为大家详细介绍了C语言实现推箱子小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现推箱子游戏的具体代码,供大家参考,具体内容如下

#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.选关\n");
 printf("0.退出\n");
}
 
void xuanguan()
{
 int choice_level;
 while(1)
 {
 printf("请选择关卡:\n");
 scanf("%d",&choice_level);
 switch(choice_level)
 {
 case 1:
 level1();
 break;
 case 2:
 level2();
 break;
 default:
 printf("输入错误,请重新选择关卡!"); 
 
 }
 }
}
 
 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("恭喜你,过关啦!");
  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("第一关\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("欢迎来到第二关\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;
 } 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C语言16进制与ASCII字符相互转换

    C语言16进制与ASCII字符相互转换

    大家好,本篇文章主要讲的是C语言16进制与ASCII字符相互转换,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01
  • C语言数组越界引发的死循环问题解决

    C语言数组越界引发的死循环问题解决

    本文主要介绍了C语言数组越界引发的死循环问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • C++LeetCode数据结构基础详解

    C++LeetCode数据结构基础详解

    这篇文章主要介绍了C++实现LeetCode数据结构,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • 纯C语言:折半查找源码分享

    纯C语言:折半查找源码分享

    这篇文章主要介绍了纯C语言:折半查找源码,有需要的朋友可以参考一下
    2014-01-01
  • 使用代码验证linux子进程与父进程的关系

    使用代码验证linux子进程与父进程的关系

    Linux下父进程可以使用fork 函数创建子进程,但是当父进程先退出后,子进程会不会也退出呢?通过下面这个小实验,我们能够很好的看出来
    2014-02-02
  • C++继承与菱形继承详细介绍

    C++继承与菱形继承详细介绍

    继承(inheritance)机制是面向对象程序设计使代码可以复用的最重要的手段,它允许程序员在保持原有类特性的基础上进行扩展,增加功能,这样产生新的类,称派生类。继承呈现了面向对象程序设计的层次结构,体现了由简单到复杂的认知过程
    2022-08-08
  • C++ 数据结构线性表-数组实现

    C++ 数据结构线性表-数组实现

    这篇文章主要介绍了C++ 数据结构线性表-数组实现的相关资料,需要的朋友可以参考下
    2017-06-06
  • C语言基础函数用法示例详细解析

    C语言基础函数用法示例详细解析

    最接地气的C函数基础介绍,此处对于函数的相关知识点做一些简要的介绍,作者实属初学,写博客也是作者学习的一个过程,难免文章中有内容理解不到位或者有不当之处,还请朋友们不吝指正
    2021-11-11
  • 完美解决QT QGraphicsView提升到QChartView报错的问题

    完美解决QT QGraphicsView提升到QChartView报错的问题

    使用QT提供的QChartView来绘制图表,提升QGraphicsView控件继承QChartView后,然后将QGraphicsView提升到我们自己写的类,怎么才能确保提升后编译不报错呢,下面小编给大家带来了QT QGraphicsView 提升到QChartView报错解决方案,感兴趣的朋友一起看看吧
    2023-05-05
  • C语言学习笔记之字符串间的那些事

    C语言学习笔记之字符串间的那些事

    字符串是C语言中最重要的数据类型之一,最近借助《C Primer Plus》一书来学习C中的常用字符串操作,在此作为笔记记录,下面这篇文章主要给大家介绍了C语言学习笔记之字符串间的那些事,需要的朋友可以参考下
    2022-04-04

最新评论