2021秋季《数据结构》_EOJ 1085.华师大卫星照片

2023-10-08 08:20

本文主要是介绍2021秋季《数据结构》_EOJ 1085.华师大卫星照片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

jim 通过 Google 得到了华师大WH像素的卫星照片( 1 ≤ W ≤ 80 , 1 ≤ H ≤ 1000 1\leq W\leq 80,1\leq H\leq 1000 1W80,1H1000 ,希望找出最大的 ” 连续的 “(互相连接的) 建筑。对于一个建筑的任何一对像素,其中一个像素如果能横向的或纵向的与属于这个建筑的另一个像素相连,这样的建筑称作是连续的。每一张照片都数字化了,建筑区显示为 ““, 非建筑区显示为 “.”。

下面是一个 10 × 5 的卫星照片样例 :

…*…**

.***

.

…*.

…*.

这张照片显示了大小分别为 4、16、6 个像素的连续建筑区。帮助 jim 在他的每张卫星照片中找到最大的连续建筑。
在这里插入图片描述

思路

摆了好久没写oj了)

  • 嗯dfs,需要注意的是sum的取值,本来把sum作为全局变量,在dfs内部比较,但这样会导致sum的多余更新,使得答案比真实结果更小。参考了讨论区,将每个局部变量sum传参进入dfs
  • 把h和w以不同形式弄反了好几次,需要注意
    • define
    • 声明地图和画地图

代码

#include<bits/stdc++.h>
using namespace std;
#define MAXH 1001
#define MAXW 81int w, h;
int book[MAXH][MAXW] = { {0} };
// 0:未走过
char Map[MAXH][MAXW];
int dir[4][2] = {{1,0},{-1,0},{0,1},{0,-1}
};int maxSum = 0;
void dfs(int x, int y, int& sum)
{if (!(x >= 1 && x <= h && y >= 1 && y <= w))return;for (int i = 0; i < 4; i++){int tx = x + dir[i][0];int ty = y + dir[i][1];// 是建筑且没走过if (Map[tx][ty] == '*' && book[tx][ty] == 0){sum++;book[tx][ty] = 1;dfs(tx, ty, sum);}}return;
}int main()
{cin >> w >> h;for (int i = 1; i <= h; i++){for (int j = 1; j <= w; j++){char tmp; cin >> tmp;Map[i][j]=tmp;book[i][j]=0;}}for (int i = 1; i <= h; i++){for (int j = 1; j <= w; j++){if (Map[i][j] == '*' && book[i][j] == 0)  // 找到没走过的建筑点{int sum = 1;book[i][j] = 1;dfs(i, j, sum);if (sum > maxSum)maxSum = sum;}}}cout << maxSum << endl;return 0;
}

这篇关于2021秋季《数据结构》_EOJ 1085.华师大卫星照片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/163972

相关文章

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

《数据结构(C语言版)第二版》第八章-排序(8.3-交换排序、8.4-选择排序)

8.3 交换排序 8.3.1 冒泡排序 【算法特点】 (1) 稳定排序。 (2) 可用于链式存储结构。 (3) 移动记录次数较多,算法平均时间性能比直接插入排序差。当初始记录无序,n较大时, 此算法不宜采用。 #include <stdio.h>#include <stdlib.h>#define MAXSIZE 26typedef int KeyType;typedef char In

【408数据结构】散列 (哈希)知识点集合复习考点题目

苏泽  “弃工从研”的路上很孤独,于是我记下了些许笔记相伴,希望能够帮助到大家    知识点 1. 散列查找 散列查找是一种高效的查找方法,它通过散列函数将关键字映射到数组的一个位置,从而实现快速查找。这种方法的时间复杂度平均为(

浙大数据结构:树的定义与操作

四种遍历 #include<iostream>#include<queue>using namespace std;typedef struct treenode *BinTree;typedef BinTree position;typedef int ElementType;struct treenode{ElementType data;BinTree left;BinTre

Python 内置的一些数据结构

文章目录 1. 列表 (List)2. 元组 (Tuple)3. 字典 (Dictionary)4. 集合 (Set)5. 字符串 (String) Python 提供了几种内置的数据结构来存储和操作数据,每种都有其独特的特点和用途。下面是一些常用的数据结构及其简要说明: 1. 列表 (List) 列表是一种可变的有序集合,可以存放任意类型的数据。列表中的元素可以通过索

浙大数据结构:04-树7 二叉搜索树的操作集

这道题答案都在PPT上,所以先学会再写的话并不难。 1、BinTree Insert( BinTree BST, ElementType X ) 递归实现,小就进左子树,大就进右子树。 为空就新建结点插入。 BinTree Insert( BinTree BST, ElementType X ){if(!BST){BST=(BinTree)malloc(sizeof(struct TNo

GPU 计算 CMPS224 2021 学习笔记 02

并行类型 (1)任务并行 (2)数据并行 CPU & GPU CPU和GPU拥有相互独立的内存空间,需要在两者之间相互传输数据。 (1)分配GPU内存 (2)将CPU上的数据复制到GPU上 (3)在GPU上对数据进行计算操作 (4)将计算结果从GPU复制到CPU上 (5)释放GPU内存 CUDA内存管理API (1)分配内存 cudaErro

【数据结构入门】排序算法之交换排序与归并排序

前言         在前一篇博客,我们学习了排序算法中的插入排序和选择排序,接下来我们将继续探索交换排序与归并排序,这两个排序都是重头戏,让我们接着往下看。  一、交换排序 1.1 冒泡排序 冒泡排序是一种简单的排序算法。 1.1.1 基本思想 它的基本思想是通过相邻元素的比较和交换,让较大的元素逐渐向右移动,从而将最大的元素移动到最右边。 动画演示: 1.1.2 具体步

2021-8-14 react笔记-2 创建组件 基本用法

1、目录解析 public中的index.html为入口文件 src目录中文件很乱,先整理文件夹。 新建components 放组件 新建assets放资源   ->/images      ->/css 把乱的文件放进去  修改App.js 根组件和index.js入口文件中的引入路径 2、新建组件 在components文件夹中新建[Name].js文件 //组件名首字母大写