IIlIIlllIIll 2015-10-30 22:20 采纳率: 60%
浏览 2825
已采纳

c语言设计俄罗斯方块判断能否下落问题

我会用字摸点阵的方法保存每个方块的形状,并且能用掩码的方式画出来,但很
难判断能否下落。
我判断能否左右移动的算法是:用掩码分别计算每一行最左或最右的方块位置,然后在最左边那则不能移动块旁边的中点取颜色,如果不是黑色则不能移动。

 // 检查左边界
int Left(int x, int y, unsigned int binary_code)
{
    int i;
    int leftmost = 0;   // 最左端与x的的距离
    int pix_in_line = 0;    // 标志一行是否有方块
    int mask = 1;   // 设置掩码

    for(i = 1; i<=16; i++, binary_code >>= 1)
    {
        if((mask & binary_code) == 1)
        {
            if(i%4 > leftmost)
                leftmost = i%4;
            if(i == 4)
                leftmost = 4;
            pix_in_line = 1;
        }
        x -= LEN;
        if(i%4 == 0)
        {
            x += 4*LEN;
            if(pix_in_line == 1)
            {
                if(getpixel(x - leftmost*LEN - LEN/2, y + LEN/2) != BLACK)
                    return 1;
                else if(x - leftmost*LEN == 0)
                    return 1;
            }
            y += LEN;
            leftmost = 0;
            pix_in_line = 0;
        }
    }
    return 0;
}

按这种方法判断下边界的要用两个for循环,很麻烦。网上的代码看上去没这么麻烦,但我看不懂,有哪位大神能提供下思路吗?谢谢!

展开全部

  • 写回答

1条回答 默认 最新

  • hyb1996 2015-10-30 23:26
    关注

    为什么不用a[m][n]数组表示位置(i,j)是否有方块 判断能否下落就是判断下落的方块(a[i1][j1], a[i2][j2], a[i3][j4],...)最下面的一个(j最大)的下面(j+1)是否有方块即可

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

悬赏问题

  • ¥15 TMUXHS4412如何防止静电,
  • ¥30 Metashape软件中如何将建模后的图像中的植被与庄稼点云删除
  • ¥20 机械振动学课后习题求解答
  • ¥15 IEC61850 客户端和服务端的通讯机制
  • ¥15 MAX98357a(关键词-播放音频)
  • ¥15 Linux误删文件,请求帮助
  • ¥15 IBMP550小型机使用串口登录操作系统
  • ¥15 关于#python#的问题:现已知七自由度机器人的DH参数,利用DH参数求解机器人的逆运动学解目前使用的PSO算法
  • ¥15 发那科机器人与设备通讯配置
  • ¥15 Linux环境下openssl报错
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部