蓝桥杯每日一题2023.9.18

蓝桥杯2022年第十三届省赛真题-统计子矩阵 - C语言网 (dotcpp.com)

题目描述

给定一个 N × M 的矩阵 A,请你统计有多少个子矩阵 (最小 1 × 1,最大 N × M) 满足子矩阵中所有数的和不超过给定的整数 K?

分析

如果不考虑范围问题等,可以用二位前缀和,一步一步列举

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 1e4 + 10;
int n, m, k, ans, a[N][N], s[N][N];
int main()
{
	cin >> n >> m >> k;
	for(int i = 1; i <= n; i ++)
	{
		for(int j = 1; j <= m; j ++)
		{
			cin >> a[i][j];
		}
	}
	for(int i = 1; i <= n; i ++)
	{
		for(int j = 1; j <= m; j ++)
		{
			s[i][j] = s[i - 1][j] + s[i][j - 1] - s[i - 1][j - 1] + a[i][j];
		}
	}
	ans = 0;
	for(int x1 = 1; x1 <= n; x1 ++)
	{
		for(int y1 = 1; y1 <= m; y1 ++)
		{
			for(int x2 = x1; x2 <= n; x2 ++)
			{
				for(int y2 = y1; y2 <= m; y2 ++)
				{
					if (s[x2][y2] - s[x1 - 1][y2] - s[x2][y1 - 1] + s[x1 - 1][y1 - 1] <= k)ans ++;
				}
			}
		}
	}
	cout << ans;
	return 0;
}

但是四重循环会使时间超限

故可以考虑优化

将上下边界进行循环,使用双指针来列出左右边界,由于范围一定 <= k,故超过这个的话就移动指针

将上下枚举出来就可以看成一个一维问题,可以将每一列看成一个元素,相当于一个一维数组,在这个数组里找到哪些区间 <= k

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 1e4 + 10;
int n, m, k, sum, ans, a[N][N], s[N][N];
int main()
{
	cin >> n >> m >> k;
	for(int i = 1; i <= n; i ++)
	{
		for(int j = 1; j <= m; j ++)
		{
			cin >> a[i][j];
		}
	}
	for(int i = 1; i <= n; i ++)
	{
		for(int j = 1; j <= m; j ++)
		{
			s[i][j] = s[i - 1][j] + a[i][j];//算出这一列的前缀和 
		}
	}
	for(int i = 1; i <= n; i ++)//枚举上边界 
	{
		for(int j = i; j <= n; j ++)//枚举下边界 
		{
			for(int l = 1, r = 1, sum = 0; r <= m; r ++)//枚举左右边界 
			{
			 	sum += s[j][r] - s[i - 1][r];
			 	while(sum > k)
			 	{
			 		sum -= s[j][l] - s[i - 1][l];
			 		l ++;
				}
				ans += r - l + 1;
			} 
		}
	}
	cout << ans;
	return 0;
}
相关推荐
不过四级不改名6772 小时前
蓝桥杯嵌入式备赛教程(1、led,2、lcd,3、key)
stm32·嵌入式硬件·蓝桥杯
TT哇2 小时前
*【每日一题 提高题】[蓝桥杯 2022 国 A] 选素数
java·算法·蓝桥杯
chengooooooo4 小时前
代码随想录训练营第二十七天| 贪心理论基础 455.分发饼干 376. 摆动序列 53. 最大子序和
算法·leetcode·职场和发展
测试杂货铺5 小时前
如何用postman做接口自动化测试及完美的可视化报告?
自动化测试·软件测试·测试工具·职场和发展·jenkins·压力测试·postman
TT哇7 小时前
*【每日一题 基础题】 [蓝桥杯 2023 省 B] 飞机降落
算法·蓝桥杯
撞上电子7 小时前
蓝桥杯物联网开发板硬件组成
物联网·职场和发展·蓝桥杯
pzx_0017 小时前
【LeetCode】LCR 175.计算二叉树的深度
开发语言·c++·算法·leetcode·职场和发展
Aloha_up7 小时前
LeetCode hot100-89
算法·leetcode·职场和发展
测试老哥10 小时前
Jmeter测试脚本编写技巧
自动化测试·软件测试·功能测试·测试工具·jmeter·职场和发展·性能测试
逝灮11 小时前
【蓝桥杯——物联网设计与开发】拓展模块4 - 脉冲模块
stm32·单片机·嵌入式硬件·mcu·物联网·蓝桥杯·脉冲测量