本人技术很菜,但还是想写个小游戏玩,虽然写的不是很好,诺,就是这个东西。2048主要考虑移动和合并。然后随机生成值,生成的值就由一个4*4的二维数组保存。
先进行移动,移动时进行判断,int[4]={0,1,0,3} 先将第一个值记录,判断相邻的元素是否为0,如果为0跳过,如果不为0,
swap(0,1) //0,1,0,3 ->1,0,0,3 记录第二个值 swap(0,3) //1,0,0,3->1,3,0,0 ,就是这么个循环,下面是代码。
void Widget::upMove(int array[][N])
{
for(int j=0;j<N;j++)
{
for(int i=0;i<N;i++)
{
if(array[i][j]==0)
{
for(int k=i+1;k<N;k++)
{
if(array[k][j]==0)continue;
else
{
int temp=array[i][j];
array[i][j]=array[k][j];
array[k][j]=temp;
break;
}
}
}
}
}
}
移动之后就是进行合并,判断相邻元素是否相等,如果相等a[i]=a[i]*2;a[i+1]=0;就做这么个操作。同样的贴代码。
void Widget::upmerge(int array[][N])
{
for(int j=0;j<N;j++)
{
for(int i=1;i<N;)
{
if(array[i][j]==array[i-1][j])
{
array[i-1][j]=array[i][j]*2;
score+=array[i][j]*2;
labelScore->setText("分数:"+QString::number(score));
array[i][j]=0;
i+=2;
}else
{
i++;
}
}
}
}
完整的代码我上传到github地址https://github.com/itsSoHardToName/Qt/tree/master/2048_1.1,编程一直在自己瞎琢磨,很多东西都不明白,代码看起来可能会很杂乱,请见谅。