当前位置: 首页 > news >正文

算法 day 53

岛屿周长

很反直觉的一道题目,并不需要用到bfs和dfs。下意识就去写dfs结果发现并不是这么一回事。

遍历每一个空格,遇到岛屿则计算其上下左右的空格情况。如果该陆地上下左右的空格是有水域,则说明是一条边,陆地的右边空格是水域,则说明找到一条边。如果该陆地上下左右的空格出界了,则说明是一条边,该陆地的下边空格出界了,则说明找到一条边。

#include <iostream>
#include <vector>
using namespace std;
int main() {int n, m;cin >> n >> m;vector<vector<int>> grid(n, vector<int>(m, 0));for (int i = 0; i < n; i++) {for (int j = 0; j < m; j++) {cin >> grid[i][j];}}int direction[4][2] = {0, 1, 1, 0, -1, 0, 0, -1};int result = 0;for (int i = 0; i < n; i++) {for (int j = 0; j < m; j++) {if (grid[i][j] == 1) {for (int k = 0; k < 4; k++) {       // 上下左右四个方向int x = i + direction[k][0];int y = j + direction[k][1];    // 计算周边坐标x,yif (x < 0                       // x在边界上|| x >= grid.size()     // x在边界上|| y < 0                // y在边界上|| y >= grid[0].size()  // y在边界上|| grid[x][y] == 0) {   // x,y位置是水域result++;}}}}}cout << result << endl;}

字符串接龙

力扣的一道hard题目,依旧是一个情况,思路不难代码难写。

1、图中的线是如何连在一起的

在搜索的过程中,我们可以枚举,用26个字母替换当前字符串的每一个字符,在看替换后 是否在 strList里出现过,就可以判断 两个字符串 是否是链接的。

2、起点和终点的最短路径长度

首先题目中并没有给出点与点之间的连线,而是要我们自己去连,条件是字符只能差一个。

所以判断点与点之间的关系,需要判断是不是差一个字符,如果差一个字符,那就是有链接

然后就是求起点和终点的最短路径长度,在无权图中,求最短路,用深搜或者广搜就行,没必要用最短路算法。

在无权图中,用广搜求最短路最为合适,广搜只要搜到了终点,那么一定是最短的路径。因为广搜就是以起点中心向四周扩散的搜索。

本题如果用深搜,会比较麻烦,要在到达终点的不同路径中选则一条最短路

而广搜只要达到终点,一定是最短路。

另外需要有一个注意点:

  • 本题是一个无向图,需要用标记位,标记着节点是否走过,否则就会死循环!
  • 使用set来检查字符串是否出现在字符串集合里更快一些
#include <iostream>
#include <vector>
#include <string>
#include <unordered_set>
#include <unordered_map>
#include <queue>
using namespace std;
int main() {string beginStr, endStr, str;int n;cin >> n;unordered_set<string> strSet;cin >> beginStr >> endStr;for (int i = 0; i < n; i++) {cin >> str;strSet.insert(str);}// 记录strSet里的字符串是否被访问过,同时记录路径长度unordered_map<string, int> visitMap; // <记录的字符串,路径长度>// 初始化队列queue<string> que;que.push(beginStr);// 初始化visitMapvisitMap.insert(pair<string, int>(beginStr, 1));while(!que.empty()) {string word = que.front();que.pop();int path = visitMap[word]; // 这个字符串在路径中的长度// 开始在这个str中,挨个字符去替换for (int i = 0; i < word.size(); i++) {string newWord = word; // 用一个新字符串替换str,因为每次要置换一个字符// 遍历26的字母for (int j = 0 ; j < 26; j++) {newWord[i] = j + 'a';if (newWord == endStr) { // 发现替换字母后,字符串与终点字符串相同cout <<  path + 1 << endl; // 找到了路径 return 0;}// 字符串集合里出现了newWord,并且newWord没有被访问过if (strSet.find(newWord) != strSet.end()&& visitMap.find(newWord) == visitMap.end()) {// 添加访问信息,并将新字符串放到队列中visitMap.insert(pair<string, int>(newWord, path + 1));que.push(newWord);}}}}// 没找到输出0cout << 0 << endl;}

有向图的完全联通

是一个类似bool的返回值,所以可以说是有向图的入门题了,找好思路并不难。

// 写法一:dfs 处理当前访问的节点
#include <iostream>
#include <vector>
#include <list>
using namespace std;void dfs(const vector<list<int>>& graph, int key, vector<bool>& visited) {if (visited[key]) {return;}visited[key] = true;list<int> keys = graph[key];for (int key : keys) {// 深度优先搜索遍历dfs(graph, key, visited);}
}int main() {int n, m, s, t;cin >> n >> m;// 节点编号从1到n,所以申请 n+1 这么大的数组vector<list<int>> graph(n + 1); // 邻接表while (m--) {cin >> s >> t;// 使用邻接表 ,表示 s -> t 是相连的graph[s].push_back(t);}vector<bool> visited(n + 1, false);dfs(graph, 1, visited);//检查是否都访问到了for (int i = 1; i <= n; i++) {if (visited[i] == false) {cout << -1 << endl;return 0;}}cout << 1 << endl;
}

http://www.dtcms.com/a/606800.html

相关文章:

  • 基础算法理解
  • 链表7--------查找2:给数传值
  • 电脑终端(不用软件)直连树莓派
  • Android AB升级(一) - 升级各层级模块概述
  • 沈阳网站开发培训价格冬奥会建设官方网站
  • 365科技简报 2025年11月13日 星期四
  • 医院做网站怎么就违规了论文格式样板模板
  • 建设不动产网站工业设计专业是干什么的
  • Redis 常见八股(不定期更新)
  • 做网站用什么网名好什么是最经典最常用的网站推广方式
  • 网站优化的基本思想网架公司赵娜
  • 哪里有做网站app的支部建设杂志官方网站
  • 选型指南:电流检测芯片 TI INA139 VS FP137 详解 如何根据关键参数选择?
  • module ‘torch.compiler‘ has no attribute ‘is_compiling‘
  • c 网站开发教程海城建设网站
  • 揭阳网站推广教程网站刷链接怎么做
  • C语言编程实战:每日刷题 - day2
  • 大模型运维
  • 今科网站建设费用职业生涯规划书模板
  • 第三方网站备案做男女的那个视频网站
  • 可信数据空间通用架构图全解:打破数据孤岛,实现安全互信
  • 对于位姿的理解
  • 【git】--远程Git仓库的名称发生更改
  • 建筑网站设置工资单人换了怎么换手游推广渠道平台
  • Unity 的URP渲染模式下,灯光只影响个别物体
  • 四合一网站郑州seo技术
  • 脚本语言与编译语言的区别与应用 | 深入探讨两者的特点与适用场景
  • 深度学习_神经网络激活函数
  • js 原型链分析
  • 深圳网站订制开发qq做我女朋友好吗网站