Othello UVa220

Time: 3 hrs.

这种棋啊什么玩意的题目是真的烦,情况没考虑好就要WA,而且对于我这种弱鸡代码写的非常冗余。

本题输出有很多坑,uDebug调试AC后,竟然还是WA。

无奈拿着这个代码自己和自己下黑白棋,最后无意间发现在边界的时候会有迷之吃子。

虽然分析代码后,发现问题不大?还是最后加了宏is进行判断,终于AC。

写的太丑了Orz。

#include <cstdio>
#include <cstring>
#define is(x) x>=1&&x<=8
using namespace std;
char map[10][10] = { '\0' };
char f(char x)
{
    if (x == 'W')
        return 'B';
    else
        return 'W';
}
int isPlace(int tot, int x, int y, int t)//tot代表当前回合玩家,xy为目标点位
{
    if (map[x][y] != '-')
        return 0;

    int flag[10] = { 0 };
    char oth = f(tot);//表示对手

    flag[0] = (map[x][y + 1] == oth) && y + 1 <= 8;
    flag[1] = (map[x][y - 1] == oth) && y - 1 >= 1;
    flag[2] = (map[x + 1][y] == oth) && x + 1 <= 8;
    flag[3] = (map[x - 1][y] == oth) && x - 1 >= 1;
    flag[4] = (map[x - 1][y + 1] == oth) && x - 1 >= 1 && y + 1 <= 8;
    flag[5] = (map[x + 1][y + 1] == oth) && x + 1 <= 8 && y + 1 <= 8;
    flag[6] = (map[x + 1][y - 1] == oth) && x + 1 <= 8 && y - 1 >= 1;
    flag[7] = (map[x - 1][y - 1] == oth) && x - 1 >= 1 && y - 1 >= 1;

    for (int i = 2; i <= 7; i++)
    {
        if (flag[0] == 1 && is(y + i))
            if (map[x][y + i] == tot)
                flag[0] = 2;
            else if (map[x][y + i] == '-')
                flag[0] = 0;

        if (flag[1] == 1 && is(y - i))
            if (map[x][y - i] == tot)
                flag[1] = 2;
            else if (map[x][y - i] == '-')
                flag[1] = 0;

        if (flag[2] == 1 && is(x + i))
            if (map[x + i][y] == tot)
                flag[2] = 2;
            else if (map[x + i][y] == '-')
                flag[2] = 0;

        if (flag[3] == 1 && is(x - i))
            if (map[x - i][y] == tot)
                flag[3] = 2;
            else if (map[x - i][y] == '-')
                flag[3] = 0;

        if (flag[4] == 1 && is(x - i) && is(y + i))
            if (map[x - i][y + i] == tot)
                flag[4] = 2;
            else if (map[x - i][y + i] == '-')
                flag[4] = 0;

        if (flag[5] == 1 && is(x + i) && is(y + i))
            if (map[x + i][y + i] == tot)
                flag[5] = 2;
            else if (map[x + i][y + i] == '-')
                flag[5] = 0;

        if (flag[6] == 1 && is(x + i) && is(y - i))
            if (map[x + i][y - i] == tot)
                flag[6] = 2;
            else if (map[x + i][y - i] == '-')
                flag[6] = 0;

        if (flag[7] == 1 && is(x - i) && is(y - i))
            if (map[x - i][y - i] == tot)
                flag[7] = 2;
            else if (map[x - i][y - i] == '-')
                flag[7] = 0;

    }
    if (t)
    {
        for (int i = 1; i <= 7; i++)
        {
            if (flag[0] == 2)
                if (map[x][y + i] == oth)
                    map[x][y + i] = tot;
                else
                    flag[0] = 3;

            if (flag[1] == 2)
                if (map[x][y - i] == oth)
                    map[x][y - i] = tot;
                else
                    flag[1] = 3;

            if (flag[2] == 2)
                if (map[x + i][y] == oth)
                    map[x + i][y] = tot;
                else
                    flag[2] = 3;

            if (flag[3] == 2)
                if (map[x - i][y] == oth)
                    map[x - i][y] = tot;
                else
                    flag[3] = 3;

            if (flag[4] == 2)
                if (map[x - i][y + i] == oth)
                    map[x - i][y + i] = tot;
                else
                    flag[4] = 3;

            if (flag[5] == 2)
                if (map[x + i][y + i] == oth)
                    map[x + i][y + i] = tot;
                else
                    flag[5] = 3;

            if (flag[6] == 2)
                if (map[x + i][y - i] == oth)
                    map[x + i][y - i] = tot;
                else
                    flag[6] = 3;

            if (flag[7] == 2)
                if (map[x - i][y - i] == oth)
                    map[x - i][y - i] = tot;
                else
                    flag[7] = 3;
        }
    }
    for (int i = 0; i < 8; i++)
        if (flag[i] >= 2)
        {
            return 1;

        }
    return 0;
}
int main()
{
    //freopen("in.txt", "r", stdin);
    //freopen("out.txt", "w", stdout);
    int T, kase = 0;
    scanf("%d", &T);
    while (T--)
    {
        memset(map, '\0', sizeof map);
        char tot, cmd[5];
        for (int i = 1; i <= 8; i++)
        {
            getchar();
            for (int j = 1; j <= 8; j++)
                scanf("%c", &map[i][j]);

        }
        getchar();
        scanf("%c", &tot);

        if (kase++)
            printf("\n");

        while (scanf("%s", cmd) && cmd[0] != 'Q')
        {
            if (cmd[0] == 'L')
            {
                int flag = 0;
                for (int i = 1; i <= 8; i++)
                    for (int j = 1; j <= 8; j++)
                        if (isPlace(tot, i, j, 0))
                        {
                            if (flag++)
                                printf(" ");
                            printf("(%d,%d)", i, j);
                        }
                if (!flag)
                    printf("No legal move.");
                printf("\n");
            }
            else
            {
                int x = cmd[1] - '0', y = cmd[2] - '0';
                if (!isPlace(tot, x, y, 1))
                {
                    tot = f(tot);
                    isPlace(tot, x, y, 1);
                }
                map[x][y] = tot;
                tot = f(tot);
                int s1 = 0, s2 = 0;
                for (int i = 1; i <= 8; i++)
                    for (int j = 1; j <= 8; j++)
                        if (map[i][j] == 'B')
                            s1++;
                        else if (map[i][j] == 'W')
                            s2++;
                printf("Black - %2d White - %2d\n", s1, s2);
            }
        }
        for (int i = 1; i <= 8; i++)
            printf("%s\n", map[i] + 1);
    }
    return 0;
}

内容概要:《2024年中国城市低空经济发展指数报告》由36氪研究院发布,指出低空经济作为新质生产力的代表,已成为中国经济新的增长点。报告从发展环境、资金投入、创新能力、基础支撑和发展成效五个维度构建了综合指数评价体系,评估了全国重点城市的低空经济发展状况。北京和深圳在总指数中名列前茅,分别以91.26和84.53的得分领先,展现出强大的资金投入、创新能力和基础支撑。低空经济主要涉及无人机、eVTOL(电动垂直起降飞行器)和直升机等产品,广泛应用于农业、物流、交通、应急救援等领域。政策支持、市场需求和技术进步共同推动了低空经济的快速发展,预计到2026年市场规模将突破万亿元。 适用人群:对低空经济发展感兴趣的政策制定者、投资者、企业和研究人员。 使用场景及目标:①了解低空经济的定义、分类和发展驱动力;②掌握低空经济的主要应用场景和市场规模预测;③评估各城市在低空经济发展中的表现和潜力;④为政策制定、投资决策和企业发展提供参考依据。 其他说明:报告强调了政策监管、产业生态建设和区域融合错位的重要性,提出了加强法律法规建设、人才储备和基础设施建设等建议。低空经济正加速向网络化、智能化、规模化和集聚化方向发展,各地应找准自身比较优势,实现差异化发展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值