C++实现连连看消除算法

 更新时间:2019年01月03日 16:04:15   作者:求索路途  
这篇文章主要为大家详细介绍了C++实现连连看消除算法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

C++连连看消除代码的实现,过程比较复杂。

#include<iostream>
#include<vector>
using namespace std;
bool CheckRemove(int x1,int y1,int x2,int y2,int rows,int cols,int ***pArray);
void Swap(int &a,int &b);
typedef struct
{
 int x;
 int y;
}point;
int main()
{
 int Num=0;
 while(Num<=15)
 {
 int m,n,t;
 cin>>m>>n>>t;
 int **store_num=new int*[m];
 int **t_pos=new int*[t];
 for(int i=0;i<m;i++)
 {
 store_num[i]=new int[n];
 }
 for(int i=0;i<m;i++)
 {
 for(int j=0;j<n;j++)
 {
 store_num[i][j]=0;
 }
 }
 for(int i=0;i<t;i++)
 {
 t_pos[i]=new int[4];
 }
 for(int i=0;i<t;i++)
 {
 for(int j=0;j<4;j++)
 {
 t_pos[i][j]=0;
 }
 }
 for(int i=0;i<m;i++)
 {
 for(int j=0;j<n;j++)
 {
 cin>>store_num[i][j];
 }
 }
 for(int i=0;i<t;i++)
 {
 for(int j=0;j<4;j++)
 {
 cin>>t_pos[i][j];
 }
 }
 int score=0;
 for(int i=0;i<t;i++)
 {
 if(CheckRemove(t_pos[i][0],t_pos[i][1],t_pos[i][2],t_pos[i][3],m,n,&store_num))
 {
 score++;
 }
 }
 cout<<score<<endl;
 Num++;
 }
 return 0;
}
bool CheckRemove(int x1,int y1,int x2,int y2,int rows,int cols,int ***pArray)
{
 
 int m1=x1-1;int n1=y1-1;
 int m2=x2-1;int n2=y2-1;
 if((*pArray)[m1][n1]!=(*pArray)[m2][n2])
 {
 return false;
 }
 if(m1==m2&&(m1==0||m1==rows-1))
 {
 (*pArray)[m1][n1]=0;
 (*pArray)[m2][n2]=0;
 return true;
 }
 if(n1==n2&&(n1==0||n1==cols-1))
 {
 (*pArray)[m1][n1]=0;
 (*pArray)[m2][n2]=0;
 return true;
 }
 vector<point>v_point;
 point p_in;
 int **pArray_incre=new int*[rows+2];
 for(int i=0;i<rows+2;i++)
 {
 pArray_incre[i]=new int [cols+2];
 }
 for(int i=0;i<rows+2;i++)
 {
 for(int j=0;j<cols+2;j++)
 {
 pArray_incre[i][j]=0;
 }
 }
 for(int i=1;i<rows+1;i++)
 {
 for(int j=1;j<cols+1;j++)
 {
 pArray_incre[i][j]=(*pArray)[i-1][j-1];
 }
 }
 for(int y=y1+1;y<cols+2;y++)
 {
 if(pArray_incre[x1][y]!=0)
 {
 break;
 }
 p_in.x=x1;
 p_in.y=y;
 v_point.push_back(p_in);
 }
 for(int y=0;y<y1;y++)
 {
 if(pArray_incre[x1][y]!=0)
 {
 break;
 }
 p_in.x=x1;
 p_in.y=y;
 v_point.push_back(p_in);
 }
 for(int y=y2+1;y<cols+2;y++)
 {
 if(pArray_incre[x2][y]!=0)
 {
 break;
 }
 p_in.x=x2;
 p_in.y=y;
 v_point.push_back(p_in);
 }
 for(int y=0;y<y2;y++)
 {
 if(pArray_incre[x2][y]!=0)
 {
 break;
 }
 p_in.x=x2;
 p_in.y=y;
 v_point.push_back(p_in);
 }
 for(int i=0;i<(int)v_point.size();i++)
 {
 for(int j=0;j<(int)v_point.size();j++)
 {
 if(j!=i)
 {
 if(v_point[i].y==v_point[j].y)
 {
 int yy=v_point[i].y;
 int xx1=v_point[i].x;
 int xx2=v_point[j].x;
 if(xx1>xx2)
 Swap(xx1,xx2);
 int num=xx2-xx1+1;
 int count=0;
 for(int h=xx1;h<=xx2;h++)
 {
 if(pArray_incre[h][yy]==0)
 {
 count++;
 }
 }
 if(count==num)
 {
 (*pArray)[x1-1][y1-1]=0;
 (*pArray)[x2-1][y2-1]=0;
 v_point.empty();
 return true;
 }
 }
 }
 }
 }
 v_point.empty();
 for(int x=x1+1;x<rows+2;x++)
 {
 if(pArray_incre[x][y1]!=0)
 {
 break;
 }
 p_in.x=x;
 p_in.y=y1;
 v_point.push_back(p_in);
 }
 for(int x=0;x<x1;x++)
 {
 if(pArray_incre[x][y1]!=0)
 {
 break;
 }
 p_in.x=x;
 p_in.y=y1;
 v_point.push_back(p_in);
 }
 for(int x=x2+1;x<rows+2;x++)
 {
 if(pArray_incre[x][y2]!=0)
 {
 break;
 }
 p_in.x=x;
 p_in.y=y2;
 v_point.push_back(p_in);
 }
 for(int x=0;x<x2;x++)
 {
 if(pArray_incre[x][y2]!=0)
 {
 break;
 }
 p_in.x=x;
 p_in.y=y2;
 v_point.push_back(p_in);
 }
 for(int i=0;i<(int)v_point.size();i++)
 {
 for(int j=0;j<(int)v_point.size();j++)
 {
 if(j!=i)
 {
 if(v_point[i].x==v_point[j].x)
 {
 int xx=v_point[i].x;
 int yy1=v_point[i].y;
 int yy2=v_point[j].y;
 if(yy1>yy2)
 Swap(yy1,yy2);
 int num=yy2-yy1+1;
 int count=0;
 for(int h=yy1;h<=yy2;h++)
 {
 if(pArray_incre[xx][h]==0)
 {
 count++;
 }
 }
 if(count==num)
 {
 (*pArray)[x1-1][y1-1]=0;
 (*pArray)[x2-1][y2-1]=0;
 v_point.empty();
 return true;
 }
 }
 }
 }
 }
 
 
 return false;
}
void Swap(int &a,int &b)
{
 int tmp;
 tmp=a;
 a=b;
 b=tmp;
}

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

相关文章

  • 一文详解C++中隐含的this指针

    一文详解C++中隐含的this指针

    这篇文章主要带大家详细了解一下C++中隐含的this指针,文中通过代码示例和图文介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-01-01
  • C++ 命名空间 using声明使用示例详解

    C++ 命名空间 using声明使用示例详解

    这篇文章主要为大家介绍了C++ 命名空间 using声明使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • 使用C++进行Cocos2d-x游戏开发入门过程中的要点解析

    使用C++进行Cocos2d-x游戏开发入门过程中的要点解析

    这篇文章主要介绍了使用C++进行Cocos2d-x游戏开发入门过程中的要点解析,主要针对画面变化以及触摸响应方面,需要的朋友可以参考下
    2015-12-12
  • C++中std::vector的具体使用

    C++中std::vector的具体使用

    C++标准库中的std::vector是一种动态数组容器,适用于算法竞赛中的动态数据存储、数组扩展和模拟栈/二维数组等场景,本文就来介绍一下,感兴趣的可以了解一下
    2025-02-02
  • 解析C语言中位字段内存分配的问题

    解析C语言中位字段内存分配的问题

    本篇文章是对C语言中位字段内存分配的问题进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C++中的Qt QTableView详解

    C++中的Qt QTableView详解

    这篇文章主要介绍了Qt QTableView详解,主要包括常用接口,设置item属性,右键弹出菜单,结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • C语言的进制转换及算法实现教程

    C语言的进制转换及算法实现教程

    这篇文章主要介绍了C语言的进制转换及算法实现的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • Qt两种定时器使用实现方式

    Qt两种定时器使用实现方式

    这篇文章主要给大家介绍了关于Qt两种定时器使用实现方式的相关资料,Qt中的定时器类是QTimer,QTimer不是一个可见的界面组件,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • C语言中#if的使用详解

    C语言中#if的使用详解

    #if和#endif是一组同时使用的,叫做条件编译指令。#if与#define、#include等指令一样是由预处理器这个强大的工具处理的,预处理器可以在编译前处理c程序,这篇文章主要介绍了C语言中#if的使用,需要的朋友可以参考下
    2022-11-11
  • 详解C++纯虚函数与抽象类

    详解C++纯虚函数与抽象类

    这篇文章主要介绍了C++纯虚函数与抽象类的相关资料,帮助大家更好的理解和学习c++,感兴趣的朋友可以了解下
    2020-08-08

最新评论