#include <stdio.h>

#include <malloc.h>

#include <string.h>

/*

1 2 1 2

2 1 2 1

2 1 2 2

1 1 2 2    只对比上下左右,如果有相等的,赋为零

*/

void xiaochu(int i_compare, int x, int y ,int p[][4])

{

if(x-1>= 0)

{

   if(p[x-1][y] == i_compare)

   {

    p[x-1][y] = 0;

    x = x -1;

   

     int d[4][4];



     for(int i = 0;i<4;i++)

     {

      for(int j = 0;j<4;j++)

      d[i][j] = p[i][j];

}

return xiaochu(i_compare, x, y, d);

   }

}

if(x+1< 4)

{

   if(p[x+1][y] == i_compare)

   {

    p[x+1][y] = 0;

    x = x +1;

int d[4][4];

for(int i = 0;i<4;i++)

    {

     for(int j = 0;j<4;j++)

      d[i][j] = p[i][j];

}

    return xiaochu(i_compare, x, y, d);

   }

}

if(y -1>=0)

{

   if(p[x][y-1] == i_compare)

   {

    p[x][y-1] = 0;

    y = y -1;

   

     int d[4][4];



     for(int i = 0;i<4;i++)

     {

      for(int j = 0;j<4;j++)

      d[i][j] = p[i][j];

}

return xiaochu(i_compare, x, y, d);

   }

}

if(y + 1<4)

{

   if(p[x][y+1] == i_compare)

   {

    p[x][y+1] = 0;

    y = y +1;

   

     int d[4][4];



     for(int i = 0;i<4;i++)

     {

      for(int j = 0;j<4;j++)

      d[i][j] = p[i][j];

}

return xiaochu(i_compare, x, y, d);

   }

}

for(int i = 0;i<4;i++)

{

   for(int j = 0;j<4;j++)

    printf("%d ",p[i][j]);

   printf("\n ");

}

}

void main()

{

int p[4][4] = {{1,2,1, 2 },{2,1,2,1},{2,1,2,2}, {1,1,2,2}};

//printf("%d", p[0][0]);

int i_compare = p[1][2];

p[1][2] = 0;

int x = 1,y =2;

printf(" ");

xiaochu(i_compare, x, y, p);

}

VC 类泡泡龙游戏算法的更多相关文章

  1. 【Nodejs】“快算24”扑克牌游戏算法

    算24是一款扑克牌游戏,它的游戏方式是把四张牌的牌面数值通过四则运算得到结果24,四张牌必须仅用一次.这是一种挺好的锻炼孩子算数能力的扑克牌游戏. 各地玩法还有点差别,有的只算1-10,其它抽出来:有 ...

  2. php实现 24点游戏算法

    php实现 24点游戏算法 一.总结 一句话总结:把多元运算转化为两元运算,先从四个数中取出两个数进行运算,然后把运算结果和第三个数进行运算,再把结果与第四个数进行运算.在求表达式的过程中,最难处理的 ...

  3. 【Android开发VR实战】三.开发一个寻宝类VR游戏TreasureHunt

    转载请注明出处:http://blog.csdn.net/linglongxin24/article/details/53939303 本文出自[DylanAndroid的博客] [Android开发 ...

  4. WEBGL学习笔记(七):实践练手1-飞行类小游戏之游戏控制

    接上一节,游戏控制首先要解决的就是碰撞检测了 这里用到了学习笔记(三)射线检测的内容了 以鸟为射线原点,向前.上.下分别发射3个射线,射线的长度较短大概为10~30. 根据上一节场景的建设,我把y轴设 ...

  5. Unity《ATD》塔防RPG类3D游戏架构设计(二)

    目录 <ATD> 游戏模型 <ATD> 游戏逻辑 <ATD> UI/HUD/特效/音乐 结语 前篇:Unity<ATD>塔防RPG类3D游戏架构设计(一 ...

  6. Unity《ATD》塔防RPG类3D游戏架构设计(一)

    目录 <ATD> 游戏简介 <ATD> 整体结构 <ATD> 游戏机制 Buff机制 Skill机制(技能机制) 仇恨机制 <ATD> 游戏模型 策划案 ...

  7. 基于Lua的清除类游戏算法

    最近在开发游戏,用Lua语言.习惯了其它的语言,然后对Lua的一些语法很不习惯. 比如table的元素个数的取值,比switch语句等等. 不过没有办法,还是要运用Lua来写游戏的.看来学C++还真的 ...

  8. [安卓] 12、开源一个基于SurfaceView的飞行射击类小游戏

    前言  这款安卓小游戏是基于SurfaceView的飞行射击类游戏,采用Java来写,没有采用游戏引擎,注释详细,条理比较清晰,适合初学者了解游戏状态转化自动机和一些继承与封装的技巧. 效果展示    ...

  9. android开发之网络棋牌类在线游戏开发心得(服务器端、Java) 好文章值得收藏

    标签: android服务器 2013-10-09 17:28 3618人阅读 评论(0) 收藏 举报 分类: android(11) 转自:http://blog.csdn.net/bromon/a ...

随机推荐

  1. [原]Fedora Linux环境下的应用工具总结

    一.办公类软件 1.Office办公:WPS 二.网络通信类软件 1.浏览器:Chrome 2.远程桌面:rdesktop(适用于Windows系列) 三.操作系统设置与优化 1.3D桌面管理:Com ...

  2. 【shell】case语句

    case只能判断一种条件关系,而if能判断多种条件关系 #!/bin/bash read -p "please input your choice (high/middle/low):&qu ...

  3. FullCalendar

    一个非常完美的日期控件:https://fullcalendar.io/

  4. 【Spring-AOP-1】AOP相关概念

    Advice (好多中文书籍翻译为:增强处理,比如前向增强.后向增强等) 描述了Aspect类执行的具体动作.the job of an aspect. 定义了如下两个方面: what:即Aspect ...

  5. 【freemaker】之Unknown built-in variable: now

    Caused by: freemarker.core.ParseException: Unknown built-in variable: now 意思是没有内置变量,看了一下源码2.3.15版本fr ...

  6. ASP.NET 中的 authentication(验证)与authorization(授权)

    这两个东西很绕口,也绕脑袋. 一般来说,了解authentication(验证)的用法即可,用于自定义的用户验证. authorization(授权)主要通过计算机信息来控制. “*”:所有用户: “ ...

  7. JavaScript 中 4 种常见的内存泄露陷阱

    了解 JavaScript 的内存泄露和解决方式! 在这篇文章中我们将要探索客户端 JavaScript 代码中常见的一些内存泄漏的情况,并且学习如何使用 Chrome 的开发工具来发现他们.读一读吧 ...

  8. DBA_Oracle Erp加密和解密账户密码(案例)

    2014-09-09 Created By BaoXinjian

  9. PKU 2406 Power Strings(KMP最长循环不重叠字串)

    题意:给一个字符串S长度不超过10^6,求最大的n使得S由n个相同的字符串a连接而成,如:"ababab"则由n=3个"ab"连接而成,"aaaa&q ...

  10. SPOJ 694. Distinct Substrings (后缀数组不相同的子串的个数)转

    694. Distinct Substrings Problem code: DISUBSTR   Given a string, we need to find the total number o ...