每日练习之深度优先搜索——最大的湖

news2025/1/15 10:02:59

最大的湖

题目描述

 

运行代码

#include<iostream>
using namespace std;
bool mp[102][102];
int sum,num;
int N,M,K;
int dfs(int x,int y )
{
	 if( mp[x][y] )
	 {
	 	mp[x][y]=0;
        sum++;
        dfs(x+1,y);
        dfs(x-1,y);
        dfs(x,y+1);
        dfs(x,y-1);
	 }
	 return 0;
}
int main()
{
	cin>>N>>M>>K;
	int x,y;
	for( int i=1;i<=K;i++ )
	{
			cin>>x>>y;
			mp[x][y]=1;
	}
	for( int i=1;i<=N;i++ )
	{
		for( int j=1;j<=M;j++ )
		{
				sum=0;
				dfs(i,j);
				num=max(num,sum);
			
		}
	}
   cout<<num;
	return 0;
}
代码思路
  1. 初始化
    • 定义了一个二维数组mp,用于表示网格的状态,其中1表示已占用或可达的位置,0表示空位置。
    • 定义了三个整数变量sumnumK,以及两个整数变量NM,分别用于表示当前连通块的大小、最大连通块的大小、已标记的位置数量、网格的行数和列数。
  2. 读取输入
    • 从标准输入读取网格的行数N、列数M和已占用位置的个数K
    • 使用循环读取K个已占用位置的坐标(x, y),并在mp数组中将其标记为1。
  3. DFS遍历
    • 使用了两层嵌套循环遍历整个网格的每一个位置(i, j)
    • 对于每一个位置(i, j),都重置sum为0,然后调用dfs函数来搜索以(i, j)为起点的连通块大小。
    • dfs函数递归地访问当前位置的上下左右四个相邻位置,如果相邻位置是已占用的(即mp[x][y]为1),则将其标记为已访问(即mp[x][y]设为0)并将sum加1。然后继续递归访问该相邻位置的相邻位置。
    • 在每次dfs调用结束后,使用max函数更新num为当前连通块大小sumnum中的较大值。
  4. 输出结果:在遍历完整个网格后,输出最大连通块的大小num

改进建议

问题
  1. 变量初始化num没有初始化为0,这可能会导致未定义的行为,因为num可能包含任意值。
  2. DFS逻辑:在dfs函数中,你递归地探索了当前位置的四个方向(上、下、左、右)。但是,你没有检查递归调用是否越界(即,是否仍然在网格内)。
  3. 不必要的重复计算:在main函数中,你使用了两层循环遍历整个网格,并对每个位置都调用dfs。但是,一旦你找到一个1并调用了dfs,你就不需要再次对同一个位置调用dfs,因为该位置及其连通块已经被标记为0了。
  4. 性能问题:由于上述不必要的重复计算,该代码的性能非常差。
改进方向
  1. 初始化变量:在main函数的开始处,将num初始化为0。
  2. 边界检查:在dfs函数中,添加边界检查以确保递归调用不会越界。
  3. 避免重复计算:在遍历网格时,只对值为1的位置调用dfs,并在调用后立即将其标记为已访问(例如,使用另一个布尔数组或将其值更改为一个特殊的“已访问”值)。
  4. 使用队列或栈进行BFS或DFS:虽然递归DFS在这里可以工作,但使用队列或栈可能会更清晰,并减少递归调用栈的深度。

改进代码

#include<iostream>  
#include<vector>  
#include<algorithm>  
using namespace std;  
bool mp[102][102];  
bool visited[102][102]; // 用于标记已访问的位置  
int maxArea = 0;  
void dfs(int x, int y, int& area, int N, int M) {  
    if (x < 1 || x > N || y < 1 || y > M || !mp[x][y] || visited[x][y]) return;  
    visited[x][y] = true;  
    area++;  
    dfs(x+1, y, area, N, M);  
    dfs(x-1, y, area, N, M);  
    dfs(x, y+1, area, N, M);  
    dfs(x, y-1, area, N, M);  
}   
int main() {  
    int N, M, K;  
    cin >> N >> M >> K;  
    int x, y;  
    for (int i = 0; i < K; i++) {  
        cin >> x >> y;  
        mp[x][y] = true;  
    }  
    for (int i = 1; i <= N; i++) {  
        for (int j = 1; j <= M; j++) {  
            if (mp[i][j] && !visited[i][j]) {  
                int area = 0;  
                dfs(i, j, area, N, M);  
                maxArea = max(maxArea, area);  
            }  
        }  
    }  
    cout << maxArea << endl;  
    return 0;  
}
代码思路
  1. 初始化
    • 声明了两个二维数组mpvisited,其中mp用于存储网格的初始状态(0表示空,1表示占用),visited用于标记在DFS过程中已经访问过的位置。
    • 声明了一个变量maxArea来记录找到的最大连通块的大小,并将其初始化为0。
  2. 读取输入
    • 从输入中读取网格的维度NM,以及占用位置的个数K
    • 对于每个占用位置,读取其坐标(x, y),并在mp数组中将其标记为1。
  3. DFS遍历
    • 使用两层循环遍历整个网格。
    • 对于每个位置(i, j),如果它是占用的(mp[i][j]为1)且尚未被访问过(visited[i][j]false),则调用DFS函数来搜索该位置所在的连通块。
    • 在DFS函数中,首先检查当前位置(x, y)是否在网格内、是否被占用且未被访问过。如果是,则将其标记为已访问,并将当前连通块的大小加1。
    • 然后,递归地调用DFS函数来搜索当前位置的上、下、左、右四个相邻位置。
    • 每次DFS调用结束后,更新maxArea为当前连通块大小和maxArea中的较大值。
  4. 输出结果:在遍历完整个网格后,输出找到的最大连通块的大小maxArea

注意点:改进代码为  AI优化原代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1691163.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ubuntu 源码安装 cloudcompare

1.系统环境&#xff1a; ubuntu18 cmake&#xff1a;3.10.2 官方安装指导&#xff1a;https://github.com/CloudCompare/CloudCompare/blob/master/BUILD.md (注&#xff1a;查看cmake版本&#xff1a; cmake --version) 2.安装依赖 sudo apt-get update sudo apt-get insta…

Android 屏保开关

设置-显示-屏保&#xff0c; 打开关闭 设置代码在 ./packages/apps/Settings/src/com/android/settings/dream/DreamMainSwitchPreferenceController.java &#xff0c; Overridepublic boolean isChecked() {return mBackend.isEnabled();}Overridepublic boolean setChecke…

【云原生】Kubernetes----POD基本管理

目录 引言 一、Pod基础概念 &#xff08;一&#xff09;Pod简介 &#xff08;二&#xff09;Pod的分类 1.自主式Pod 2.控制器管理的Pod &#xff08;三&#xff09;Pod使用方式 1.单容器pod 2.多容器Pod 3. 注意事项 二、Pod容器的分类 &#xff08;一&#xff09;…

FL Studio2025新功能大揭秘,你准备好了吗?

FL Studio&#xff0c;常被音乐制作者亲切地称为“水果”编曲软件&#xff0c;是比利时的Image-Line公司研发的一款完整的软件音乐生产环境或数字音频工作站&#xff08;DAW&#xff09;。自从1997年推出以来&#xff0c;它已经成为全世界众多电子音乐制作者和DJ的首选工具&…

【中霖教育口碑】什么情况下不允许参加注册会计师考试?

对于某些特殊情况&#xff0c;存在明确的禁止性规定&#xff0c;是不能参加注册会计师考试的&#xff0c;中霖为大家分享一下!关于注册会计师全国统一考试的资格条件&#xff0c;需明确以下要点&#xff1a; 1. 针对在前期注册会计师统一考试中因违反规定而受到禁止参加考试的…

抽象工厂模式(AbstractFactoryPattern)

文章目录 1.抽象工厂模式定义2.UML类图3.抽象工厂模式具体实现工厂模式实现单一产品族抽象工厂实现多产品族产品类工厂类使用 4.抽象工厂模式优缺点 1.抽象工厂模式定义 提供一个创建一系列相关或相互依赖对象的接口&#xff0c;而无需指定它们具体的类。 工厂方法模式是单一产…

1、Docker之技术架构演进之路

1、Docker之技术架构演进之路 概述常见概念基本概念应用&#xff08;Application&#xff09;/ 系统&#xff08;System&#xff09;模块&#xff08;Module&#xff09;/ 组件&#xff08;Component&#xff09;分布式&#xff08;Distributed&#xff09;集群&#xff08;Clu…

OpenStack配置 之 不同cpu迁移虚拟机

介绍 OpenStack是一个开源的云计算管理平台项目&#xff0c;是一系列软件开源项目的组合。 OpenStack由NASA&#xff08;美国国家航空航天局&#xff09;和Rackspace合作研发并发起&#xff0c;以Apache许可证&#xff08;Apache软件基金会发布的一个自由软件许可证&#xff…

基于antd的DatePicker 组件封装业务组件

先看一下我写的目录结构: 依次来看业务代码; (1)RangeTime.tsx import {useState,uesCallback} from react; import {DatePicker} from antd; import {RangePickerProps as AntdRangePickerProps} from antd/es/date-picker; import {Moment} from moment; import type {Ran…

【Spring Security系列】权限之旅:SpringSecurity小程序登录深度探索

作者&#xff1a;后端小肥肠 创作不易&#xff0c;未经允许严禁转载。 姊妹篇&#xff1a; 【Spring Security系列】Spring SecurityJWTRedis实现用户认证登录及登出_spring security jwt 退出登录-CSDN博客 1. 前言 欢迎来到【Spring Security系列】&#xff01;在当今数字化…

【Java】/*类和对象(下)*/

目录 一、封装 1.1 初识封装 1.2 如何封装成员变量 1.3 如何使用封装后的成员变量 二、访问限定符 三、包 3.1 包的概念 3.2 如何自定义包 3.3 导入包中的类 3.4 包的访问权限控制举例 示例一&#xff1a;private修饰成员变量 示例二&#xff1a; 不去修饰成员变…

网络拓扑—DNS服务搭建

文章目录 DNS服务搭建网络拓扑配置网络DNSPC 安装DNS服务配置DNS服务创建正向查找区域创建反向查找区域创建子域名 PC机DNS域名解析 DNS服务搭建 网络拓扑 为了节省我的U盘空间&#xff0c;没有用路由器&#xff0c;所以搭建的环境只要在同网段即可。 //交换机不用考虑 DNS&a…

hugging face笔记:PEFT

1 介绍 PEFT (Parameter-Efficient Fine Tuning) 方法在微调时冻结预训练模型参数&#xff0c;并在其上添加少量可训练的参数&#xff08;称为适配器&#xff09;这些适配器被训练用来学习特定任务的信息。这种方法已被证明在内存效率和计算使用上非常高效&#xff0c;同时能产…

靠着单干实现财富自由,可太爽了

这里所说的“单干”&#xff0c;并不是单打独斗的意思&#xff0c;而是一种商业认知&#xff0c;以及由这种认知衍生出来的商业模式、商业方法和商业实践。 之前提到单干&#xff0c;会本能地以为它是指脱离公司等组织形式&#xff0c;自己一个人做生意。现在单干有了更丰富的…

第十二章 网络编程

第十二章 网络编程 网络协议概述 通信协议&#xff1a; 协议即规则&#xff0c;就好比汽车上路要遵守交通规则一样&#xff0c;为了使全世界不同类型的计算机都可以连接起来&#xff0c;所以制定了一套全球通用的通信协议——Internet协议。有了Internet协议&#xff0c;任何…

【网络技术】【Kali Linux】Wireshark嗅探(十二)NBNS协议报文捕获及分析

往期 Kali Linux 上的 Wireshark 嗅探实验见博客&#xff1a; 【网络技术】【Kali Linux】Wireshark嗅探&#xff08;一&#xff09;ping 和 ICMP 【网络技术】【Kali Linux】Wireshark嗅探&#xff08;二&#xff09;TCP 协议 【网络技术】【Kali Linux】Wireshark嗅探&…

Swift 类和结构体

类和结构体 一、结构体和类对比1、类型定义的语法2、结构体和类的实例3、属性访问4、结构体类型的成员逐一构造器 二、结构体和枚举是值类型三、类是引用类型1、恒等运算符2、指针 结构体和类作为一种通用而又灵活的结构&#xff0c;成为了人们构建代码的基础。你可以使用定义常…

汇舟问卷:海外问卷调查如何闭坑?

大家好&#xff0c;我是汇舟问卷。有很多人问我这行有什么骗局吗&#xff1f;怎么说呢&#xff1f;其实每个行业都是真实存在的&#xff0c;也都有赚到钱的和赚不到钱的&#xff0c;那区别在哪里呢&#xff1f; 在你的源头&#xff0c;也就是教你或者说是代理加盟的上家&#…

LabVIEW舱段测控系统开发

LabVIEW舱段测控系统开发 在航空技术飞速发展的当下&#xff0c;对于航空器的测控系统的需求日益增加&#xff0c;特别是对舱段测控系统的设计与实现。开发了一款基于LabVIEW开发的舱段测控系统&#xff0c;包括系统设计需求、系统组成、工作原理以及系统实现等方面。 开发了…

电赛经验分享——赛前准备

⏩ 大家好哇&#xff01;我是小光&#xff0c;想要成为系统架构师的嵌入式爱好者。 ⏩在之前的电赛中取得了省一的成绩&#xff0c;本文对电赛比赛前需要准备什么做一个经验分享。 ⏩感谢你的阅读&#xff0c;不对的地方欢迎指正。 加入小光嵌入式交流群&#xff08;qq群号&…