news 2026/6/1 17:41:13

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/5/31 22:59:31

基于SSM+Vue的汽车票网上预订系统的设计与实现

前言 本汽车票网上预订系统管理员和用户。管理员功能有个人中心&#xff0c;用户管理&#xff0c;汽车票管理&#xff0c;订单管理&#xff0c;退票管理&#xff0c;换票管理&#xff0c;反馈管理&#xff0c;留言板管理&#xff0c;系统管理等。用户功能有个人中心&#xff0…

作者头像 李华
网站建设 2026/5/31 5:21:03

专业指南:SFP光模块使用与维护的最佳实践

在企业机房与数据中心中&#xff0c;SFP光模块作为一种核心的光电转换组件&#xff0c;承担着设备间数据传输的关键角色&#xff0c;堪称网络架构中的“核心枢纽”。尽管其体积小巧&#xff0c;但若安装或使用不当&#xff0c;极易引发网络性能下降或设备故障。本文系统梳理了S…

作者头像 李华
网站建设 2026/6/1 5:37:43

测试工具链的构建与团队协作:从工具集成到价值流动

在当今快速迭代的软件开发环境中&#xff0c;孤立的测试工具和分散的测试活动已成为效率的瓶颈。构建一个无缝集成、高效协作的测试工具链&#xff0c;不再是可选项&#xff0c;而是保障产品质量、加速交付周期的核心基础设施。本文旨在为软件测试从业者提供一个系统性的视角&a…

作者头像 李华
网站建设 2026/6/1 5:53:08

安卓离线语音识别实战:Vosk语音引擎开发全攻略

安卓离线语音识别实战&#xff1a;Vosk语音引擎开发全攻略 【免费下载链接】vosk-android-demo alphacep/vosk-android-demo: Vosk Android Demo 是一个演示项目&#xff0c;展示了如何在Android平台上使用Vosk语音识别引擎进行实时语音转文本功能。Vosk是开源的离线语音识别库…

作者头像 李华
网站建设 2026/6/1 5:02:15

R语言数据可视化神器:ggplot2完整入门指南

R语言数据可视化神器&#xff1a;ggplot2完整入门指南 【免费下载链接】ggplot2 An implementation of the Grammar of Graphics in R 项目地址: https://gitcode.com/gh_mirrors/gg/ggplot2 ggplot2是R语言中最受欢迎的数据可视化包&#xff0c;它基于图形语法理论&…

作者头像 李华