840. 矩阵中的幻方

840. 矩阵中的幻方


题目链接:840. 矩阵中的幻方

代码如下:

cpp 复制代码
class Solution {
public:
	int numMagicSquaresInside(vector<vector<int>>& grid) {
		int m = grid.size(),n = grid[0].size();
		int res = 0;

		for (int i = 0;i < m - 2;i++) {
			for (int j = 0;j < n-2;j++) {
				 if (grid[i + 1][j + 1] != 5) {
                    continue;
                }

				int mask = 0;
				int r_sum[3]{};
				int c_sum[3]{};
				for (int r = 0;r < 3;r++) {
					for (int c = 0;c < 3;c++) {
						int x = grid[i + r][j + c];
						mask |= 1 << x;
						r_sum[r] += x;
						c_sum[c] += x;
					}
				}

				if (mask == (1 << 10) - 2 &&
					r_sum[0] == 15 && r_sum[1] == 15 &&
					c_sum[0] == 15 && c_sum[1] == 15) {
					res++;
				}
			}
		}

		return res;
	}
};
相关推荐
梵尔纳多18 小时前
第一个 3D 图像
c++·图形渲染·opengl
xiaoqider18 小时前
C++继承
开发语言·c++
YE1234567_18 小时前
从底层零拷贝到分布式架构:深度剖析现代 C++ 构建超大规模高性能 AI 插件引擎的实战之道
c++·分布式·架构
脏脏a18 小时前
C++ 容器的两把利器:优先级队列与反向迭代器
c++·反向迭代器·优先级队列
张张努力变强18 小时前
C++ 类和对象(三):拷贝构造函数与赋值运算符重载之核心实现
开发语言·c++
_OP_CHEN18 小时前
【算法基础篇】(五十)扩展中国剩余定理(EXCRT)深度精讲:突破模数互质限制
c++·算法·蓝桥杯·数论·同余方程·扩展欧几里得算法·acm/icpc
福楠18 小时前
C++ STL | set、multiset
c语言·开发语言·数据结构·c++·算法
enfpZZ小狗18 小时前
基于C++的反射机制探索
开发语言·c++·算法
王老师青少年编程19 小时前
2023年12月GESP真题及题解(C++七级): 纸牌游戏
c++·题解·真题·gesp·csp·七级·纸牌游戏
Trouvaille ~19 小时前
【Linux】进程间通信(一):IPC基础与管道机制深度剖析
linux·运维·c++·管道·进程间通信·匿名管道·半双工