【CSP:202104-2】邻域均值(Java)

题目链接

题目描述





求解思路

  • 二维前缀和:用s数组记录下二维数组a的前缀和。在进行查询时直接利用前缀和求平均值,可以降低时间复杂度。

  • xl表示邻域的左边界,xr表示邻域的右边界,yt表示邻域的上边界,yb表示邻域的下边界。

  • 为什么要用double类型进行比较?因为涉及除法,如果用整形的话可能会出现误差。

实现代码

java 复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();
        int L = in.nextInt();
        int r = in.nextInt();
        double t = in.nextDouble();
        int[][] a = new int[n + 1][n + 1];
        int[][] s = new int[n + 1][n + 1];
        for (int i = 1; i <= n; i++) {
            for (int j = 1; j <= n; j++) {
                a[i][j] = in.nextInt();
                s[i][j] = s[i - 1][j] + s[i][j - 1] + a[i][j] - s[i - 1][j - 1];
            }
        }
        int cnt = 0;
        for (int i = 1; i <= n; i++) {
            for (int j = 1; j <= n; j++) {
                int xl = Math.max(j - r, 1);
                int xr = Math.min(j + r, n);
                int yt = Math.max(i - r, 1);
                int yb = Math.min(i + r, n);
                double avg = (double) (s[yb][xr] - s[yb][xl - 1] - s[yt - 1][xr] + s[yt - 1][xl - 1]) /
                        ((yb - yt + 1) * (xr - xl + 1));
                if (avg <= t) {
                    cnt ++;
                }
            }
        }
        System.out.println(cnt);
    }
}
相关推荐
武昌库里写JAVA41 分钟前
39.剖析无处不在的数据结构
java·vue.js·spring boot·课程设计·宠物管理
Nelson_hehe3 小时前
Java基础第四章、面向对象
java·语法基础·面向对象程序设计
Thomas_YXQ3 小时前
Unity3D Lua集成技术指南
java·开发语言·驱动开发·junit·全文检索·lua·unity3d
ShiinaMashirol4 小时前
代码随想录打卡|Day27(合并区间、单调递增的数字、监控二叉树)
java·算法
东阳马生架构6 小时前
Nacos简介—3.Nacos的配置简介
java
北极的企鹅886 小时前
XML内容解析成实体类
xml·java·开发语言
oioihoii6 小时前
C++23 中 static_assert 和 if constexpr 的窄化布尔转换
java·jvm·c++23
聂 可 以6 小时前
调整IntelliJ IDEA当前文件所在目录(包路径)的显示位置
java·ide·intellij-idea
wuqingshun3141596 小时前
蓝桥杯 5. 交换瓶子
数据结构·c++·算法·职场和发展·蓝桥杯
东阳马生架构6 小时前
Sentinel源码—7.参数限流和注解的实现一
java·sentinel