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

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

#include
#include
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>store_num[i][j];
  }
 }
 for(int i=0;i>t_pos[i][j];
  }
 }
 int score=0;
 for(int i=0;iv_point;
 point p_in;
 int **pArray_incre=new int*[rows+2];
 for(int i=0;ixx2)
   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;xyy2)
   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++实现连连看消除算法)