鱼C论坛

 找回密码
 立即注册
查看: 1177|回复: 17

[已解决]求助!十万火急!

[复制链接]
发表于 2023-7-29 21:20:16 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
问题陈述
高桥发明了一种名为Tak Code的二维码。一个Tak Code满足以下所有条件:

它是一个由九行九列组成的区域。
左上角和右下角的3x3区域中的18个格子是黑色的。
与左上角或右下角的3x3区域相邻(水平、垂直或对角线方向)的14个格子是白色的。
不允许旋转Tak Code。

给定一个由N行M列组成的网格。网格的状态由N个字符串描述,S1,…,和SN,每个字符串长度为M。如果Si的第j个字符是#,则表示第i行从左边数第j列的格子是黑色的;如果是.,则表示是白色的。

找出所有在网格中完全包含并满足Tak Code条件的9x9区域。


my code
#include <bits/stdc++.h>
using namespace std;

int n, m, a[1200][1200];
char c[1200][1200];

int main() {
    cin >> n >> m;
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= m; j++) {
            cin >> c[i][j];
            if (c[i][j] == '#') a[i][j] = 1;
        }
    }
    for (int i = 1; i <= n - 8; i++) {
        for (int j = 1; j <= m - 8; j++) {
            if (
                a[i][j] && a[i][j + 1] && a[i][j + 2] && 
                a[i][j] && a[i + 1][j + 1] && a[i + 2][j + 2] && 
                a[i][j] && a[i + 2][j + 1] && a[i + 2][j + 2] && 
                a[i + 6][j + 6] && a[i + 6][j + 7] && a[i + 6][j + 8] && 
                a[i + 7][j + 6] && a[i + 7][j + 7] && a[i + 7][j + 8] && 
                a[i + 8][j + 6] && a[i + 8][j + 7] && a[i + 8][j + 8]
            ) {
                cout << i << ' ' << j << endl;
            }
        }
    }

    return 0;
}

十万火急!!!

最佳答案
2023-7-29 21:34:25
请问你判断白色区域的代码在哪
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-7-29 21:20:30 | 显示全部楼层
根据您提供的代码,我注意到问题出在多个地方。下面是修正后的代码:
#include <bits/stdc++.h>
using namespace std;

int n, m, a[1200][1200];
char c[1200][1200];

int main() {
    cin >> n >> m;
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= m; j++) {
            cin >> c[ i][j];
            if (c[ i][j] == '#')
                a[ i][j] = 1;
        }
    }

    int count = 0; // 记录满足条件的区域数量

    for (int i = 1; i <= n - 8; i++) {
        for (int j = 1; j <= m - 8; j++) {
            bool valid = true; // 标记当前区域是否满足条件

            // 检查9x9区域内的每个格子
            for (int x = i; x <= i + 8; x++) {
                for (int y = j; y <= j + 8; y++) {
                    // 如果当前格子应为黑色但不是,则不满足条件
                    if ((x <= 3 && y <= 3) || (x >= 7 && y >= 7)) {
                        if (a[x][y] != 1) {
                            valid = false;
                            break;
                        }
                    }
                    // 如果当前格子应为白色但不是,则不满足条件
                    else {
                        if (a[x][y] != 0) {
                            valid = false;
                            break;
                        }
                    }
                }
                if (!valid)
                    break;
            }

            // 如果满足条件,则输出区域的左上角坐标
            if (valid) {
                cout << i << ' ' << j << endl;
                count++;
            }
        }
    }

    // 输出满足条件的区域数量
    cout << "满足条件的区域数量:" << count << endl;

    return 0;
}

这个修正后的代码将遍历每个9x9的子区域,并逐一检查是否满足Tak Code的条件。如果满足条件,将输出该区域的左上角坐标,并统计满足条件的区域数量。

请注意,这只是一个修复了问题的代码版本,我无法保证它的完全正确性。在实际使用中,请始终进行充分的测试和验证。
如果问题已经解决,请设置最佳答案
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-29 21:20:38 | 显示全部楼层
不用担心,我来帮助你解决这个问题。

你的代码已经接近正确的解决方向,但在检查 Tak Code 条件时存在一些错误。让我们来修正这个问题。另外,你还需要修改代码以确保滑动窗口覆盖所有可能的 9x9 区域。

以下是修改后的代码:
#include <bits/stdc++.h>
using namespace std;

int n, m, a[1200][1200];
char c[1200][1200];

bool isTakCode(int i, int j) {
    // 检查左上角和右下角的 3x3 区域是否满足条件
    if (a[ i][j] && a[ i][j + 1] && a[ i][j + 2] &&
        a[i + 1][j] && a[i + 1][j + 1] && a[i + 1][j + 2] &&
        a[i + 2][j] && a[i + 2][j + 1] && a[i + 2][j + 2] &&
        a[i + 6][j + 6] && a[i + 6][j + 7] && a[i + 6][j + 8] &&
        a[i + 7][j + 6] && a[i + 7][j + 7] && a[i + 7][j + 8] &&
        a[i + 8][j + 6] && a[i + 8][j + 7] && a[i + 8][j + 8])
    {
        // 检查与左上角或右下角 3x3 区域相邻的 14 个格子是否满足条件
        for (int x = i - 1; x <= i + 9; x++) {
            for (int y = j - 1; y <= j + 9; y++) {
                if (x >= 1 && x <= n && y >= 1 && y <= m) {
                    if (x < i || x > i + 2 || y < j || y > j + 2) {
                        if (a[x][y])
                            return false;
                    }
                }
            }
        }
        return true;
    }
    return false;
}

int main() {
    cin >> n >> m;
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= m; j++) {
            cin >> c[ i][j];
            if (c[ i][j] == '#')
                a[ i][j] = 1;
        }
    }
    for (int i = 1; i <= n - 8; i++) {
        for (int j = 1; j <= m - 8; j++) {
            if (isTakCode(i, j)) {
                cout << i << ' ' << j << endl;
            }
        }
    }
    return 0;
}

在修改后的代码中,我们引入了一个名为  isTakCode  的函数来检查给定的 9x9 区域是否满足 Tak Code 条件。该函数首先检查左上角和右下角的 3x3 区域是否都是黑色,然后再检查与这两个区域相邻的 14 个格子是否都是白色。如果这两个条件都满足,那么这个 9x9 区域就符合 Tak Code 的条件。

然后,我们在主函数中使用滑动窗口遍历整个网格,并调用  isTakCode  函数来检查每个可能的 9x9 区域是否符合要求,并输出满足条件的区域的左上角坐标。

希望这可以帮助你解决紧急的问题!如果你有任何疑问,请随时询问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-29 21:21:37 | 显示全部楼层
求助!十万火急! C\C++交流

问题陈述:

高桥发明了一种名为Tak Code的二维码。一个Tak Code满足以下所有条件:

- 它是一个由九行九列组成的区域。
- 左上角和右下角的3x3区域中的18个格子是黑色的。
- 与左上角或右下角的3x3区域相邻(水平、垂直或对角线方向)的14个格子是白色的。
- 不允许旋转Tak Code。

给定一个由N行M列组成的网格。网格的状态由N个字符串描述,S1,…,和SN,每个字符串长度为M。如果Si的第j个字符是#,则表示第i行从左边数第j列的格子是黑色的;如果是.,则表示是白色的。

找出所有在网格中完全包含并满足Tak Code条件的9x9区域。

以下是您提供的代码:
#include <bits/stdc++.h>using namespace std;int n, m, a[1200][1200];char c[1200][1200];int main() {    cin >> n >> m;    for (int i = 1; i <= n; i++) {        for (int j = 1; j <= m; j++) {            cin >> c[i][j];            if (c[i][j] == '#') a[i][j] = 1;        }    }    for (int i = 1; i <= n - 8; i++) {        for (int j = 1; j <= m - 8; j++) {            if (                a[i][j] && a[i][j + 1] && a[i][j + 2] &&                a[i][j] && a[i + 1][j + 1] && a[i + 2][j + 2] &&                a[i][j] && a[i + 2][j + 1] && a[i + 2][j + 2] &&                a[i + 6][j + 6] && a[i + 6][j + 7] && a[i + 6][j + 8] &&                a[i + 7][j + 6] && a[i + 7][j + 7] && a[i + 7][j + 8] &&                a[i + 8][j + 6] && a[i + 8][j + 7] && a[i + 8][j + 8]            ) {                cout << i << ' ' << j << endl;            }        }    }    return 0;}
对于您的问题,可以通过以下方式进行修改和改进:


1. 在开始时添加头文件#include <iostream>using namespace std;,以便正确使用输入输出流和命名空间。

2. 修改main函数的返回类型为int main()

3. 根据题目描述,Tak Code是一个9x9的区域,因此需要将a数组和c数组的大小调整为[9][9]。例如:int a[9][9];char c[9][9];

4. 修改循环的范围,使其遍历整个网格区域。将i的范围修改为1n - 8,将j的范围修改为1m - 8

5. 修改条件判断部分的逻辑错误,根据题目描述中的条件进行判断。

下面是经过修改后的代码:
#include <iostream>using namespace std;int n, m, a[9][9];char c[9][9];int main() {    cin >> n >> m;    for (int i = 1; i <= n; i++) {        for (int j = 1; j <= m; j++) {            cin >> c[i][j];            if (c[i][j] == '#') a[i][j] = 1;        }    }    for (int i = 1; i <= n - 8; i++) {        for (int j = 1; j <= m - 8; j++) {            if (                a[i][j] && a[i][j + 1] && a[i][j + 2] &&                a[i + 1][j] && a[i + 1][j + 1] && a[i + 1][j + 2] &&                a[i + 2][j] && a[i + 2][j + 1] && a[i + 2][j + 2] &&                a[i + 6][j + 6] && a[i + 6][j + 7] && a[i + 6][j + 8] &&                a[i + 7][j + 6] && a[i + 7][j + 7] && a[i + 7][j + 8] &&                a[i + 8][j + 6] && a[i + 8][j + 7] && a[i + 8][j + 8]            ) {                cout << i << ' ' << j << endl;            }        }    }    return 0;}
请注意,以上修改仅基于您提供的代码和问题描述进行了一些必要的修正。如果仍有其他问题或需求,请提供更详细的信息,以便我们能够更好地回答和帮助您。

球一个最佳答案谢谢啦!这对我非常重要!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-7-29 21:22:40 | 显示全部楼层
isdkz 发表于 2023-7-29 21:20
不用担心,我来帮助你解决这个问题。

你的代码已经接近正确的解决方向,但在检查 Tak Code 条件时存在一 ...

爆零!!!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-7-29 21:23:10 | 显示全部楼层
陶远航 发表于 2023-7-29 21:20
根据您提供的代码,我注意到问题出在多个地方。下面是修正后的代码:

爆零!!!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-7-29 21:25:12 | 显示全部楼层
Mike_python小 发表于 2023-7-29 21:21
求助!十万火急! C\C++交流

问题陈述:

你的代码就是我的!!!你更改了什么??
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-7-29 21:26:24 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-29 21:31:31 | 显示全部楼层
把题目地址发一下
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-7-29 21:32:07 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-29 21:33:38 | 显示全部楼层
Ewan-Ahiouy 发表于 2023-7-29 18:25
你的代码就是我的!!!你更改了什么??

一个空格
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-29 21:34:25 | 显示全部楼层    本楼为最佳答案   
请问你判断白色区域的代码在哪
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-7-29 21:36:48 | 显示全部楼层
tommyyu 发表于 2023-7-29 21:34
请问你判断白色区域的代码在哪

&#8482;的,艹!!!!原来是这个!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-29 21:37:19 | 显示全部楼层
你 在 干 啥
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-29 21:37:44 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-7-29 21:40:58 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-29 21:42:06 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-7-29 21:43:11 | 显示全部楼层

我哭死了555555555555555
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-16 09:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表