代码随想录算法训练营第 53 天 |卡码网110.字符串接龙 卡码网105.有向图的完全可达性 卡码网106.岛屿的周长

news2024/12/25 15:37:19

代码随想录算法训练营

Day53 代码随想录算法训练营第 53 天 |卡码网110.字符串接龙 卡码网105.有向图的完全可达性 卡码网106.岛屿的周长


目录

  • 代码随想录算法训练营
  • 前言
    • 卡码网110.字符串接龙
    • 卡码网105.有向图的完全可达性
    • 卡码网106.岛屿的周长
  • 一、卡码网110.字符串接龙
    • 1.题目链接
    • 2.思路
    • 3.题解
  • 二、105.有向图的完全可达性
    • 1.题目链接
    • 2.思路
    • 3.题解
  • 三、卡码网106.岛屿的周长
    • 1.题目链接
    • 2.思路
    • 3.题解


前言

卡码网110.字符串接龙

讲解文档

卡码网105.有向图的完全可达性

讲解文档

卡码网106.岛屿的周长

讲解文档


一、卡码网110.字符串接龙

1.题目链接

卡码网110.字符串接龙

2.思路

(1)转换成最短路问题
在这里插入图片描述思路示意图

(2)重点要解决两个问题:
图中的线是如何连在一起的
起点和终点的最短路径长度
(3)起点和终点的最短路径长度:广度优先搜索找到的就是最短路
(4)图中的线是如何连在一起的:
相差一个字符的字符串连线,所以将之前遍历上下左右换成遍历每个字符再遍历26个字母获取新的字符串

注意:
1)用visit映射保存到每个字符串的最短路径长度,也起到防止重复的作用
2)用集合存放字符串,便于看新的字符串是否在是strlist中的
3)在制作新的字符串的时候,在遍历字符的层中string new_word=cur;防止破坏原来的字符串

3.题解

#include <bits/stdc++.h>
using namespace std;
int main()
{
    int n;
    cin>>n;
    string begin;
    string end;
    cin>>begin>>end;
    unordered_set<string>strlist;
    for(int i=0;i<n;i++)
    {
        string s1;
        cin>>s1;
        strlist.insert(s1);
    }
    unordered_map<string,int>visit;
  
    queue <string> q;
    q.push(begin);
    visit[begin]=1;
    while(!q.empty())
    {
        string cur=q.front();
        q.pop();
        int path=visit[cur];
        
        for(int j=0;j<cur.size();j++)
        {
            string new_word=cur;
            for(int k=0;k<26;k++)
            {
                new_word[j]=k+'a';
                if(new_word==end)
                {
                    cout<<path+1;
                    return 0;
                }else
                {
                    if(strlist.count(new_word) >0&& visit.count(new_word) ==0)
                    {
                        q.push(new_word);
                        visit[new_word]=path+1;
                    }
                }
                
            }
        }
    }
    cout<<0;
    return 0;
}

二、105.有向图的完全可达性

1.题目链接

105.有向图的完全可达性

2.思路

(1)存图:用数组
graph[i][j]=1指的是i->j是通路
(2)用visit标记点是否走过
最后遍历visit,如果visit里面有没走过的点,有向图不具有完全可达性,输出-1
(3)深度优先搜索遍历所有点
1)当前点index
2)遍历剩下的点
3)如果是index,是不能从index直接走过去的,已经走过的,跳过
4)标记,进行递归

3.题解

#include <bits/stdc++.h>
using namespace std;
int n;
void dfs(int index,vector<vector<int>> &graph,vector<int>&visit)
{
    for(int i=1;i<=n;i++)
    {
        if(i==index||graph[index][i]==0||visit[i])continue;
        visit[i]=1;
        dfs(i,graph,visit);
    }
}
int main()
{
    
    int k;
    cin>>n>>k;
    std::vector<vector<int>> graph(n+1,vector<int>(n+1,0)) ;
    int s;
    int t;
    for(int i=0;i<k;i++)
    {
        cin>>s>>t;
        graph[s][t]=1;
    }
    vector<int>visit(n+1,0);
    visit[1]=1;
    dfs(1,graph,visit);
    
    for(int i=1;i<n+1;i++)
    {
        if(visit[i]==0)
        {
            cout<<-1;
            return 0;
        }
    }
    cout<<1;
    return 0;
}
    

三、卡码网106.岛屿的周长

1.题目链接

卡码网106.岛屿的周长

2.思路

(1)思路:遇到岛屿则计算其上下左右的空格情况,如果空格为海洋或出界(界外为海),则说明是一条边
(2)遍历图,遇到第一个陆地点即为岛屿,对岛屿进行深度优先搜索,之后结束遍历
(3)深度优先搜索
1)边界:

  • 已经走过—返回
  • 为海洋–计数,返回
    2)当前点是没有走过的陆地:
  • 遍历上下左右
  • 如果新的点超出边界,那么说明是海洋,结果+1,continue
  • visit记录
  • 递归

3.题解

#include <bits/stdc++.h>
using namespace std;
int n;
int m;
int res=0;
int direction[4][2]={{1,0},{-1,0},{0,1},{0,-1}};
void dfs(int x,int y,vector<vector<int>> &graph,vector<vector<int>>&visit)
{
    if(visit[x][y])return;
    if(graph[x][y]==0){
        res++;
        return;
    }else
    {
        visit[x][y]=1;
        for(int i=0;i<4;i++)
        {
            int newx=x+direction[i][0];
            int newy=y+direction[i][1];
            if(newx<0||newy<0||newx>=n||newy>=m)
            {
                res++;
                continue;
            }
            dfs(newx,newy,graph,visit);
        }
    }
}
int main()
{
    cin>>n>>m;
    vector<vector<int>> graph(n+1,vector<int>(m+1,0)) ;
    vector<vector<int>> visit(n+1,vector<int>(m+1,0)) ;
    for(int i=0;i<n;i++)
    {
        for(int j=0;j<m;j++)
        {
            cin>>graph[i][j];
        }
    }
    for(int i=0;i<n;i++)
    {
        for(int j=0;j<m;j++)
        {
            if(graph[i][j]){
                dfs(i,j,graph,visit);
                break;
            }
        }
    }
    cout<<res;
    return 0;
}
    

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

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

相关文章

Java:StringBuilder、StringBuffer、StringJoiner

文章目录 StringBuilder代码为什么操作字符串建议使用StringBuilder,而不是String&#xff1f;但String还是不可替代的 StringBuffer案例&#xff1a;接收字符串&#xff0c;返回String类型的[11,22]这种形式代码 StringJoiner上面那个案例&#xff0c;用StringJoiner的方法解决…

Linux服务器不能使用su切换到其他用户

1. 现象 使用非root用户登录系统后&#xff0c;想使用su - 切换到root时&#xff0c;输入正确的密码后出现&#xff1a; 一开始以为自己密码记错了&#xff0c;或者是系统被入侵后篡改了root用户密码&#xff0c;服务器上的数据非常重要。后面不通过SSH连接&#xff0c;直接去…

2024年AI最热门行业人才:计算机视觉与自然语言及语音处理设计开发工程师!

2024年&#xff0c;计算机视觉设计与开发工程师以及自然语言及语音处理设计与开发工程师将成为技术行业中的“超级明星”。无论是智能家居、自动驾驶汽车&#xff0c;还是医疗诊断、金融服务&#xff0c;AI已经深刻融入我们的日常生活&#xff0c;而这些领域的智能化转型都离不…

《机器学习》决策树 集成学习 随机森林 参数及实例解析

目录 一、集成学习 1、含义 2、集成学习代表 1&#xff09;bagging方法 2&#xff09;boosting方法 3&#xff09;stacking方法 二、随机森林 1、什么是随机森林 2、特点 1&#xff09;数据采样随机 2&#xff09;特征选取随机 3&#xff09;森林 4&#xff09;基分类器为…

LLAMA模型解析:快速掌握大模型LLM推理入门技巧

本文借助llama这个模型快速入门LLM的推理过程&#xff0c;技术细节很多都是通用的&#xff0c;也适合其他的LLM。本篇也可以作为CV快速入门NLP简易指南。 本文借助llama这个模型快速入门LLM的推理过程&#xff0c;很多技术细节都是通用的&#xff0c;也适合其他的LLM。这篇文章…

普元EOS-微前端调用base基座的ajax

1 前言 微前端调用EOS应用的服务或API&#xff0c;需要引入base基座&#xff0c;然后使用base基座中的ajax方法。 本文将介绍微前端的高开和低开使用base基座的Ajax的方法。 强烈建议不要自己引入axios或其他ajax库&#xff0c;因为EOS的服务接口都要求身份验证和授权&#…

分页查询面试记录和面试详情

文章目录 1.分页查询面试记录1.req和vo1.InterviewHistoryReq.java2.InterviewHistoryVO.java 2.InterviewController.java3.service1.InterviewHistoryService.java2.InterviewHistoryServiceImpl.java 4.测试 2.查询面试详情1.InterviewQuestionHistoryVO.java2.InterviewCon…

适合开发人员的网页爬虫工具DrissionPage

DrissionPage是一个基于Python的网页自动化工具,它集成了Selenium和Requests的功能,既能够控制浏览器进行用户界面的模拟操作,也能够直接收发数据包进行数据的获取和处理。 开源地址:DrissionPage: 基于python的网页自动化工具。既能控制浏览器,也能收发数据包。可兼顾浏…

CLion调试ROS(包括launch启动的ROS)

打开一个终端&#xff0c;切换到工作空间目录(形如&#xff1a;&#xff5e;/catkin_ws)。 在终端输入&#xff0c;source ./devel/setup.bash 启动Clion&#xff0c;一定要在输入上述命令的窗口启动Clion&#xff0c;否则会存在一些问题。 打开工程&#xff0c;这里也是一个…

【Java】——Java实现数组元素反转的两种方法

在编程中&#xff0c;我们经常会遇到需要对数组元素进行反转的需求。例如&#xff0c;给定一个整数数组arr {1, 2, 3, 4, 5}&#xff0c;我们需要将其反转为{5, 4, 3, 2, 1}。下面我们将介绍两种实现数组元素反转的方法。 方法一&#xff1a;遍历数组一半的长度进行元素互换 …

Spring注解:优雅管理依赖的艺术

在Java企业级开发的广阔天地中&#xff0c;Spring框架以其强大的依赖注入&#xff08;DI&#xff09;和面向切面编程&#xff08;AOP&#xff09;能力&#xff0c;成为了众多开发者的首选。而Spring注解&#xff0c;作为这一框架的核心特性之一&#xff0c;更是将依赖管理提升到…

如何通过数字化资产管理提升企业运营效率

在当今快速发展的商业环境中&#xff0c;企业的资产管理正逐步向数字化迈进。数字化资产管理系统不仅帮助企业提高资产利用率&#xff0c;还能降低管理成本&#xff0c;提升整体运营效率。常达智能物联为各行业企业提供了领先的数字化资产管理解决方案&#xff0c;帮助企业实现…

AI入门指南(四):分类问题、回归问题、监督、半监督、无监督学习是什么?

文章目录 一、前言二、分类问题、回归问题是什么&#xff1f;分类问题概念常见算法分类问题的实际应用&#xff1a;银行贷款审批案例 回归问题概念常见算法回归问题实际应用&#xff1a;线性回归模型预测房价 小结 三、监督、半监督、非监督学习是什么&#xff1f;监督学习非监…

C语言基础(十五)

指针的使用&#xff1a; 测试代码1&#xff1a; #include <stdio.h> // 标准的 main 函数声明&#xff0c;包括可选的 envp 参数 int main(int argc, char *argv[], char *envp[]) { // argc 命令行参数的数量&#xff08;包括程序名&#xff09; // argv 指向字…

github源码指引:一个自制代码生成器(嵌入式脚本语言)

初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github&#xff1a;codetoys&#xff0c;所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的&#xff0c;可以在任何平台上使用。 源码目录&#xff1a;CodeTemp…

Global Illumination_Reflective Shadow Maps Deep Optimizations

之前写过一篇Global Illumination_Reflective Shadow Maps&#xff08;RSM&#xff09;、Virtual Point Light&#xff08;VPL&#xff09;&#xff0c;近期重拾传统GI技术的实际工程场景中的应用&#xff0c;于是从效率方面对RSM、LPV、VCT技术进行效率优化&#xff0c;后续逐…

HTML 全解析:从基础到实战

一、简介 HTML&#xff08;HyperText Markup Language&#xff09;即超文本标记语言&#xff0c;是用于创建网页的标准标记语言。它通过各种标签来定义网页的结构和内容&#xff0c;使得浏览器能够正确地显示网页。HTML 文档由 HTML 元素组成&#xff0c;这些元素通过标签来表…

桌面整理大师 - Mac(苹果电脑)桌面整理工具软件

桌面整理大师 与 DeskWidgets 来自同一开发者&#xff0c;是一款专为 macOS 打造的桌面分区整理工具。 与 DeskWidgets 的文件分区组件相比&#xff0c;桌面整理大师拥有更加强大的功能&#xff0c;支持调整分区的大小和样式、可快速查看非桌面目录的文件…… 桌面整理大师的宗…

【Docker】Docker学习02 | docker-cli的基本命令

本文首发于 ❄️慕雪的寒舍 简单了解一下docker client的常用命令&#xff0c;更多命令可以查看完整命令列表。不同命令之间的关系&#xff0c;可以查看下图。 如果你看不到图片&#xff0c;不用担心&#xff0c;后面对每个命令进行介绍的时候&#xff0c;会提到它们的作用的。…

内存之RAM、SRAM、DRAM、ROM、FLASH、SDRAM、DDR*(一篇文章就懂)

内存之RAM、SRAM、DRAM、ROM、FLASH、SDRAM、DDR* 内存 内存&#xff08;Memory&#xff09;指的是内存存储器&#xff0c;又称为主存&#xff0c;是CPU用来直接寻址和存储的空间&#xff0c;它相当于一座桥梁&#xff0c;用以负责诸如硬盘、主板、显卡等硬件上的数据与处理器…