news 2026/4/15 21:38:54

P2701 [USACO5.3] 巨大的牛棚 Big Barn

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
P2701 [USACO5.3] 巨大的牛棚 Big Barn

题目传送门

正方形DP

#include <bits/stdc++.h> using namespace std; // 全局变量定义 int n, t; // n: 农场大小(n×n),t: 果树数量 int a[1010][1010]; // 原始农场地图:a[i][j] = 1 表示有树,0 表示空地 int f[1010][1010]; // DP 数组:f[i][j] 表示以 (i, j) 为右下角的最大空旷正方形的边长 int ans = 0; // 记录全局最大正方形边长 int main() { // 输入农场大小 n 和果树数量 t cin >> n >> t; int x, y; // 读入 t 棵果树的位置,并在地图中标记为 1(表示不可用) while (t--) { cin >> x >> y; a[x][y] = 1; // 注意:题目坐标从 1 开始,直接使用即可 } // 动态规划填表:遍历整个 n×n 农场 for (int i = 1; i <= n; i++) { for (int j = 1; j <= n; j++) { // 如果当前位置是空地(没有树) if (a[i][j] == 0) { // 状态转移方程: // f[i][j] = min(左边, 上边, 左上角) + 1 // 原理:要形成更大的正方形,左、上、左上三个方向必须都能支撑 f[i][j] = min( min(f[i][j - 1], f[i - 1][j]), f[i - 1][j - 1] ) + 1; } // 如果 a[i][j] == 1(有树),则 f[i][j] 保持为 0(无法作为正方形的一部分) // 更新全局最大边长 ans = max(ans, f[i][j]); } } // 输出最大可建牛棚的边长 cout << ans; return 0; }

悬线法DP

#include<bits/stdc++.h> using namespace std; const int N=1010; int a[N][N],l[N][N],r[N][N],u[N][N]; int n,t,ans=0; int main() { scanf("%d%d",&n,&t); int x,y; while(t--) { scanf("%d%d",&x,&y); a[x][y]=1; } for(int i=1;i<=n;i++) { for(int j=1;j<=n;j++) { if(a[i][j]==0){ l[i][j]=r[i][j]=j; u[i][j]=1; } } } // 向左扩展:计算每行每个位置能向左延伸到的最左列 for (int i = 1; i <= n; ++i) for (int j = 2; j <= n; ++j) if (!a[i][j] && !a[i][j - 1]) l[i][j] = l[i][j - 1]; // 向右扩展:计算每行每个位置能向右延伸到的最右列 for (int i = 1; i <= n; ++i) for (int j = n - 1; j >= 1; --j) if (!a[i][j] && !a[i][j + 1]) r[i][j] = r[i][j + 1]; // 向上扩展:计算每个位置向上连续空地的高度 for (int i = 2; i <= n; ++i) for (int j = 1; j <= n; ++j) if (!a[i][j] && !a[i - 1][j]) u[i][j] = u[i - 1][j] + 1; // 动态维护左右边界并更新答案 for (int i = 1; i <= n; ++i) for (int j = 1; j <= n; ++j) { // 如果不在第一行,且当前和上方都是空地,则继承上一行的左右边界(取更紧的) if (i != 1 && !a[i][j] && !a[i - 1][j]) { l[i][j] = max(l[i][j], l[i - 1][j]); r[i][j] = min(r[i][j], r[i - 1][j]); } // 当前位置能形成的最大正方形边长 = min(宽度, 高度) // 宽度 = r[i][j] - l[i][j] + 1,高度 = Up[i][j] ans = max(ans, min(r[i][j] - l[i][j] + 1, u[i][j])); } cout << ans << endl; return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/14 4:24:44

JVM内存监测工具JConsole实战

本文采用 “理论阐述 → JConsole验证 → 实战分析” 的三段式结构&#xff0c;确保每个抽象概念都能通过可视化工具得到直观验证。第一部分&#xff1a;JConsole入门与环境准备 1.1 JConsole简介与启动 JConsole是JDK自带的图形化监控工具&#xff0c;可以实时监控JVM内存、线…

作者头像 李华
网站建设 2026/4/13 7:39:29

VLAN划分后依然互通?这些常见“误配置”是罪魁祸首

号主&#xff1a;老杨丨11年资深网络工程师&#xff0c;更多网工提升干货&#xff0c;请关注公众号&#xff1a;网络工程师俱乐部你明明建了 VLAN10、VLAN20&#xff0c;把不同部门的设备分别放进去&#xff0c;还特意做了接口隔离。结果对方还能 ping&#xff0c;你傻眼了&…

作者头像 李华
网站建设 2026/4/11 17:02:05

SpringBoot源码剖析

源码剖析 - 依赖管理问题 1&#xff1a;为什么导入 dependency 时不需要指定版本&#xff1f;在 Spring Boot 项目中&#xff0c;pom.xml 核心依赖为 spring-boot-starter-parent 和 spring-boot-starter-web&#xff0c;其中 spring-boot-starter-parent 是版本管理的核心&…

作者头像 李华
网站建设 2026/4/14 5:07:06

Tabula完整使用教程:快速从PDF提取表格数据的终极指南

Tabula完整使用教程&#xff1a;快速从PDF提取表格数据的终极指南 【免费下载链接】tabula Tabula is a tool for liberating data tables trapped inside PDF files 项目地址: https://gitcode.com/gh_mirrors/ta/tabula Tabula是一款革命性的开源工具&#xff0c;专门…

作者头像 李华
网站建设 2026/4/15 20:01:08

ANSYS Fluent完整教程:从零基础到流体动力学模拟高手

ANSYS Fluent完整教程&#xff1a;从零基础到流体动力学模拟高手 【免费下载链接】Fluent中文帮助文档1-28章完整版分享 本仓库提供了一个名为“Fluent中文帮助文档(1-28章)完整版精心整理%09包含19章、21章、24章.pdf”的资源文件下载。该文档是ANSYS Fluent的中文帮助文档&am…

作者头像 李华
网站建设 2026/4/15 20:01:06

Balena Etcher终极使用指南:轻松搞定镜像烧录

还在为系统镜像烧录烦恼吗&#xff1f;Balena Etcher这款开源神器将彻底改变您的体验&#xff01;作为一款专业的跨平台镜像写入工具&#xff0c;Etcher让复杂的系统部署变得简单直观&#xff0c;无论您是初学者还是专业人士&#xff0c;都能在几分钟内完成各种操作系统的烧录任…

作者头像 李华