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;
	}
};
相关推荐
念恒123068 分钟前
继承(下) (Inheritance)
c++
H Journey1 小时前
C++之 CMake、CMakeLists.txt、Makefile
开发语言·c++·makefile·cmake
研究点啥好呢5 小时前
Github热门项目推荐 | 创建你的像素风格!
c++·python·node.js·github·开源软件
_dindong5 小时前
cf1091div2 C.Grid Covering(数论)
c++·算法
沫璃染墨6 小时前
C++ string 从入门到精通:构造、迭代器、容量接口全解析
c语言·开发语言·c++
6Hzlia6 小时前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode
计算机安禾7 小时前
【数据结构与算法】第36篇:排序大总结:稳定性、时间复杂度与适用场景
c语言·数据结构·c++·算法·链表·线性回归·visual studio
unicrom_深圳市由你创科技7 小时前
做虚拟示波器这种实时波形显示的上位机,用什么语言?
c++·python·c#
无限进步_7 小时前
【C++】电话号码的字母组合:从有限处理到通用解法
开发语言·c++·ide·windows·git·github·visual studio
C++ 老炮儿的技术栈7 小时前
GCC编译时无法向/tmp 目录写入临时汇编文件,因为设备空间不足,解决
linux·运维·开发语言·汇编·c++·git·qt