C语言实现拼图游戏源码

 更新时间:2020年03月16日 07:32:29   作者:技术博客汇总888  
这篇文章主要为大家详细介绍了C语言实现拼图游戏源码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<conio.h>
 
 
int step=0;
 
 
void map()//游戏菜单函数。
{ printf("▇▇▇▇▇▇▇▇▇▇▇▇▇▇\n");
 printf("█ 拼 图 游 戏  █\n");
 printf("█  1. 3×3   █\n");
 printf("█  2. 4×4   █\n");
 printf("█  3. 5×5   █\n");
 printf("█  4. 退出   █\n");
 printf("▇▇▇▇▇▇▇▇▇▇▇▇▇▇\n");
}
 
 
void fun(int *a,int t,int m,int r)
{
 int i;
 int g;
 
 
 for(i=0;i<m;i++)
 {
 if(i%r==(r-1)&&(i+t)%r==0)//让数组不能跨行转换。
   continue;
  if(i%r==0&&(i+t)%r==(r-1))
   continue;
  if(a[i+t]==0 && (i+t)>=0 && (i+t)<m) 
  {
   g=a[i];
   a[i]=a[i+t];
   a[i+t]=g;
 step++;
   return ;
  }
 }
}
 
 
void move(int *a,int m,int r)
{//上下左右移动函数。
 char ch;
 int i,j;
 
 
 while(ch=getch())
 {
  system("cls");
 
 
  if(ch=='w')
  {
   i=-r;
   fun(a,i,m,r);
  }
  else if(ch=='s')
  {
   i=r;
   fun(a,i,m,r);
  }
  else if(ch=='a')
  {
   i=-1;
   fun(a,i,m,r);
  }
  else if(ch=='d')
  {
   i=1;
   fun(a,i,m,r);
  }
 else if(ch=='4')
 {
 printf("您已退出游戏,请下次再玩!\n");
 exit(0);
 }
 
 
  for(i=0;i<m;i++)
 {
 if(a[i]==0)
 printf(" ");
 else
 printf("%2d ",a[i]);
 if((i+1)%r==0)
 putchar(10);
 }
 printf("共走:%d步!\n",step);
 }
}
 
 
void map_x(int m,int r)
{
 int i=1,j,a[25],n;
 srand(time(NULL));
 printf("拼图游戏开始了:\n");
 while(i<m)
 {
 n=1+rand()%(m-1);
 for(j=1;j<i;j++)
 {
 if(n==a[j])
 break;
 }
 if(j==i)
 {
 a[i]=n;
 i++;
 }
 }
 a[0]=0;
 for(i=0;i<m;i++)
 {
 if(a[i]==0)
 printf(" ");
 else
 printf("%2d ",a[i]);
 if((i+1)%r==0)
 putchar(10);
 }
 printf("共走:%d步!\n",step);
 move(a,m,r);
}
 
 
int main()
{
 int i,n;
 char ch;
 map();//显示菜单。
 printf("请选择所玩游戏的级别:\n");
 ch=getch();
 while(ch!='1' && ch!='2' && ch!='3' &&ch!='4')
 {
 printf("输入有误,请重新输入:\n");
 ch=getch();
 }
 
 switch(ch)
 {
 case '1': 
 map_x(9,3);
 break; 
 case '2':
 map_x(16,4);
 break;
 case '3':
 map_x(25,5);
 break;
 case '4':
 printf("您已退出游戏,请下次再玩!\n");
 exit(0);
 break;
 }
 return 0;
}
 
//对于确定的循环一般用for;而不确定的循环则用while.

小编收藏的另一段拼图游戏代码,分享给大家

#include<stdio.h>
#include<stdlib.h>
#include<conio.h>
#include<time.h>
int a[25],sum=0,flag=0,i=0,j;
void Menu()//菜单
{
  puts("********************");
  puts("* 1    3x3   *");
  puts("* 2    4x4   *");
  puts("* 3    5x5   *");
  puts("* 4    退出  *");
  puts("********************");
}
int Size()//图大小
{
  int b,h;
  puts("选择:");
  scanf("%d",&b);
  system("cls");
  if(b==1)
    h=3;
  else
    if(b==2)
      h=4;
  else
    if(b==3)
      h=5;
  else
    if(b==4)
      exit(1);
  return h;//h:图长和宽
}
void Show(int a[],int n,int sum,int h)//输出
{
  system("cls");
  for(i=0;i<n;i++)
  {
    if(a[i]==0)
      printf("%3s","_");
    else
      printf("%3d",a[i]);
    if((i+1)%h==0)
      puts("");
  }
  printf("\n\n共移动了%d次!\n",sum);
}
int suiji(int h)//随机分布
{
  int n,k;
  n=h*h;
  srand(time(NULL));
  while(i<n-1)//出图
  {
    a[n-1]=0;
    k=rand()%(n-1)+1;
    for(j=0;j<i;j++)
      if(a[j]==k)
        break;
    if(j==i)
    {
      a[j]=k;
      i++;
    }
  }
  Show(a,n,sum,h);//输出
  return n;
}
 
int Move(int n,int h)//移动
{
  int y,temp;
  char f;
  y=n-1;
  while(1)
  {
    f=getch();
    if(f=='w'||f=='W')
    {
      for(i=0;i<h;i++)
        if(y==i)
          flag=1;
      if(flag!=1)
      {
        temp=a[y-h];
        a[y-h]=a[y];
        a[y]=temp;
        y=y-h;
        sum++;
      }
    }
    else
      if(f=='s'||f=='S')
      {
        for(i=0;i<h;i++)
          if(y==h*(h-1)+i)
            flag=2;
        if(flag!=2)
        {
          temp=a[y+h];
          a[y+h]=a[y];
          a[y]=temp;
          y=y+h;
          sum++;
        }
      }
    else
      if(f=='a'||f=='A')
      {
        for(i=0;i<h;i++)
          if(y==h*i)
            flag=3;
        if(flag!=3)
        {
          temp=a[y-1];
          a[y-1]=a[y];
          a[y]=temp;
          y=y-1;
          sum++;
        }
      }
    else
      if(f=='d'||f=='D')
      {
        for(i=0;i<h;i++)
          if(y==h*i+(h-1))
            flag=4;
        if(flag!=4)
        {
          temp=a[y+1];
          a[y+1]=a[y];
          a[y]=temp;
          y=y+1;
          sum++;
        }
      }
    Show(a,n,sum,h);//输出
    /*for(i=1,j=0;i<n;i++)
    {
      if(a[j]==i)
        j++;
    }
    if(j==n-1)
    {
      puts("You win!");
      exit(1);
    }*/
  }//移动
}
void Exit(int a[],int n)
{
  for(i=1,j=0;i<n;i++)
    {
      if(a[j]==i)
        j++;
    }
  if(j==n-1)
  {
    puts("You win!");
    exit(1);
  }
}
int main()
{
  int n,h,sum=0,*a;
  Menu();//菜单
  while(1)
  {
    h=Size();//图大小
    n=suiji(h);//随机分布
    Move(n,h);//移动
    Exit(a,n);
  }
  return 0;
}

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

相关文章

  • C语言超全面覆盖操作符知识点

    C语言超全面覆盖操作符知识点

    C 语言提供了丰富的操作符,有:算术操作符,移位操作符,位操作符,赋值操作符,单目操作符,关系操作符,逻辑操作符,条件操作符等。让我们通读本篇来详细了解吧
    2022-06-06
  • OpenCV使用GrabCut实现抠图功能

    OpenCV使用GrabCut实现抠图功能

    Grabcut是基于图割(graph cut)实现的图像分割算法,它需要用户输入一个bounding box作为分割目标位置,实现对目标与背景的分离/分割。本文将使用GrabCut实现抠图功能,需要的可以参考一下
    2023-02-02
  • C C++输入输出基础教程示例详解

    C C++输入输出基础教程示例详解

    当我们在网站做题的时候经常会遇到各种要求的输入输出,而且会有时间超限等多个问题,这时我们就要优化我们的输入输出或者规范我们的输入输出格式,下面介绍C和C++中的输入输出问题,有需要的朋友可以借鉴参考下,希望能够有所帮助
    2023-11-11
  • 关于C语言qsort函数详解

    关于C语言qsort函数详解

    这篇文章主要介绍了关于C语言qsort函数详解的相关资料,需要的朋友可以参考下面文章内容
    2021-09-09
  • C语言快速幂取模算法小结

    C语言快速幂取模算法小结

    这篇文章主要介绍了C语言快速幂取模算法,包括了算法的分析与改进,是很多程序设计竞赛中常见的算法,需要的朋友可以参考下
    2014-09-09
  • 基于QT实现显示OpenCV读取的图片

    基于QT实现显示OpenCV读取的图片

    OpenCV自带了一部分常用的GUI功能,但是更多的图像处理功能需要其他GUI框架来辅助实现,本文将通过QT来显示OpenCV读取的图片,需要的可以参考一下
    2022-11-11
  • QT编写tcp通信工具(Client篇)

    QT编写tcp通信工具(Client篇)

    这篇文章主要介绍了QT编写tcp通信工具,适用于Client端,类似网上常见的网络调试工具,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • C++变量判定的螺旋法则示例详解

    C++变量判定的螺旋法则示例详解

    这篇文章主要给大家介绍了关于C++变量判定的螺旋法则,文中通过示例代码介绍的非常详细,对大家学习或者使用C++具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • C语言实现航班订票系统

    C语言实现航班订票系统

    这篇文章主要为大家详细介绍了C语言实现航班订票系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • OpenCV轮廓检测之boundingRect绘制矩形边框

    OpenCV轮廓检测之boundingRect绘制矩形边框

    在进行文本检测时,我们常常会用矩形边框将检测到的内容框除。这篇文章主要为大家介绍的是OpenCV中能实现这一效果的函数:boundingRect,感兴趣的同学可以学习一下
    2021-12-12

最新评论