551 灌溉

embedded/2025/1/11 22:28:04/

 常规解法:
 

 

#include<bits/stdc++.h>
using namespace std;
int n,m,k,t;
const int N=105;
bool a[N][N],b[N][N];
int cnt;
//设置滚动数组来存贮当前和下一状态的条件
//处理传播扩散问题非常有效int main()
{cin>>n>>m>>t;for(int i=1;i<=t;i++){int x,y;cin>>x>>y;a[x][y]=1;}cin>>k;while(k--)//k次循环{for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){if(a[i][j]) b[i][j]=b[i+1][j]=b[i-1][j]=b[i][j+1]=b[i][j-1]=1;}//现在影响下一分钟的水//将自己和周围的全部更新}for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){a[i][j]=b[i][j];//将下一分钟的复制给原数组}}}for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){if(a[i][j]) cnt++;}}cout<<cnt;return 0;
}

技巧性比较强:曼哈顿路径

#include<bits/stdc++.h>
using namespace std;
int n,m,t,k,ans=0;
int x[15],y[15];
//解题的思路:
/*
问在k分钟之内能灌溉多少个,
反向转化为k分钟覆盖的范围是多少,有多少个点在这个范围之内。曼哈顿距离的联系:
题目中描述的水每经过一分钟,就会向上下左右四个方向扩展一个方格,
这种扩散方式正是曼哈顿距离所描述的移动方式。为什么满足曼哈顿距离就可以
某个方格与至少一个出水管的曼哈顿距离小于等于k,那么这个方格在k分钟后就会被灌溉。
对于一个点(1,1)和另一个点(3,4)曼哈顿距离为5,具体的来说就是右走2个下走3个。
关于题目中的扩散模式,感觉上好像是同时能够向下和向右推进,但是这不是同一个点:
即向下走完3个还需要向右走2两个,向右走完2个还需要向下走3个。
*/
int main()
{cin>>n>>m>>t;for(int i = 1;i <= t;i ++)cin >> x[i] >> y[i];int k;cin>>k;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){for(int z=1;z<=t;z++){int d=abs(x[z]-i)+abs(y[z]-j);if(d<=k){ans++;break;}}}    }cout<<ans<<'\n';return 0;
}


http://www.ppmy.cn/embedded/153139.html

相关文章

【习题】<HarmonyOS第一课>应用程序框架基础

1. 在基于Stage模型开发的应用项目中都存在一个app.json5配置文件、以及一个或多个module.json5配置文件。 正确(True) 2. 一个应用只可以包含一个UIAbility组件。 错误(False) 3. Background状态在UIAbility实例销毁时触发。可以在onDestroy()回调中进行系统资源的释放、…

GDPU Android移动应用 重点习题集

目录 程序填空 ppt摘选 题目摘选 “就这两页ppt&#xff0c;你还背不了吗” “。。。” 打开ppt后 “Sorry咯&#xff0c;还真背不了&#x1f61c;” 更新日志 考后的更新日志 没想到重点勾了一堆&#xff0c;还愣是没考到其中的内容&#xff0c;翻了一下&#xff0c;原…

ChatGPT如何赋能办公

课程背景&#xff1a; ChatGPT近来非常火爆&#xff0c;但多数课程偏重于理论&#xff0c;我们本次讲座将以亲身实践为例&#xff0c;分享如何快速赋能办公&#xff0c;并立刻提升生产力。 课程梗概&#xff1a; 本课程旨在探究ChatGPT在办公中的应用。通过案例分析、课堂讨…

【文件I/O】UNIX文件基础

IO编程的本质是通过 API 操作 文件。 什么是 IO I - Input 输入O - Output 输出 这里的输入和输出都是站在应用&#xff08;运行中的程序&#xff09;的角度。外部特指文件。 这里的文件是泛指&#xff0c;并不是只表示存在存盘中的常规文件。还有设备、套接字、管道、链接…

Spring MVC详细介绍

1.MVC 设计模式 MVC&#xff08;Model-View-Controller&#xff09;是一种常见的软件设计模式&#xff0c;用于将应用程序的逻辑分离成三个独立的组件&#xff1a; 模型&#xff08;Model&#xff09;&#xff1a;模型是应用程序的数据和业务逻辑的表示。它负责处理数据的读取…

从光子到图像——相机如何捕获世界?

引言 你是否想过为何我们按一下相机快门就可以将眼前广袤多彩的世界显示于一个小小的相机屏幕上&#xff1f;本期推文中将带着大家重现从光子转换为电子、电子转换为图像中数字驱动值的整个流程。 ▲人们通过相机捕获眼前的场景 从光子到电子的转换 光线首先通过光学镜头进入相…

详细介绍 React 中 i18n 的完整使用流程:

接下来按照步骤&#xff0c;让我们来完成&#xff01; // 1. 首先安装必要的依赖 // npm install i18next react-i18next i18next-http-backend i18next-browser-languagedetector// 2. 创建 i18n 配置文件 (src/i18n/index.js) import i18n from i18next import { initReactI…

机器学习之基本概念 - 学习算法、学习(训练)过程

机器学习是对能通过经验自动改进的计算机算法的研究. ——汤姆米切尔(Tom Mitchell)[Mitchell, 1997] 思考一个问题&#xff1a; 如何让计算机能自动识别手写的数字&#xff1f; ————------------------———————分割线—————————————————-------…