算法第五十三天:图论part04(第十一章)

一.字符串接龙

思路整理

  1. BFS建模

    • 这个题可以建模为 无权图最短路径问题

    • 图的节点:每个单词。

    • 图的边:如果两个单词只有一个字母不同,则它们之间有一条边。

    • 问题变成:从 beginStr 出发,走最少几步到达 endStr

  2. BFS核心逻辑

    • 用队列 queue 维护搜索状态,每个状态包含:

      • 当前单词 word

      • 当前步数 step

    • 初始时入队 [beginStr, 1](起点记为第1步)。

  3. 搜索过程

    • 出队一个单词 word,判断是否已经到达 endStr

      • 如果是,直接返回当前 step
    • 否则,遍历 strList,找到所有与 word 相差一个字母的单词:

      • 若该单词未被访问过,则标记为已访问并入队 (nextWord, step+1)
  4. 终止条件

    • 若 BFS 队列空了仍未找到 endStr,说明无法转换,返回 0

复制代码
from collections import deque

def judge(s1, s2):
    count = 0
    for i in range(len(s1)):
        if s1[i] != s2[i]:
            count += 1
    return count == 1


n = int(input())
beginStr, endStr = map(str, input().split())
if beginStr == endStr:
    print(0)
    exit() #直接结束整个程序
strList = []
for i in range(n):
    strList.append(input())

visited = [False for _ in range(n)]
que = deque([[beginStr, 1]])        #[beginStr, 1]:外层 [] 是为了构造队列初始内容,内层 [] 是为了把 beginStr 和 1 绑在一起
while que:
    curStr, step = que.popleft()
    if judge(curStr, endStr):
        print(step+1)
        exit()
    
    for i in range(n):
        if not visited[i] and judge(strList[i], curStr):
            visited[i] = True
            que.append([strList[i], step+1])

二.有向图的完全可达性

思路:

🚀 一、DFS(深度优先搜索)

思路:

  • 核心思想:一条路走到黑,直到走不动再回溯。

  • 递归 / 栈 实现。

  • visited(集合或数组)避免重复访问。

  • 常用于:连通分量计数、拓扑排序、判断是否有环、路径搜索。

模板:

复制代码

def dfs(node, graph, visited): if node in visited: return visited.add(node) # 遍历当前节点的所有邻居 for neighbor in graph[node]: dfs(neighbor, graph, visited)


🚀 二、BFS(广度优先搜索)

思路:

  • 核心思想:按层扩展(逐层推进)。

  • 队列 实现(collections.deque)。

  • 也需要 visited 避免重复。

  • 常用于:最短路径(无权图)、层序遍历。

模板:

复制代码

from collections import deque def bfs(start, graph): visited = set([start]) queue = deque([start]) while queue: node = queue.popleft() for neighbor in graph[node]: if neighbor not in visited: visited.add(neighbor) queue.append(neighbor)

用bfs:

复制代码
#有向图: 邻接表

import collections

def bfs(root,graph):
    visited = set()
    que = collections.deque([root])
    visited.add(root)
    while que:
        cur = que.popleft()

        for nei in graph[cur]:
            if nei not in visited:
                visited.add(nei)
                que.append(nei)
    return visited


def main():
    #读入 K 条边,构建一个 邻接表 graph
    N, K = map(int, input().split())

    graph = collections.defaultdict(list)
    for _ in range(K):
        src, dest = map(int, input().strip().split())
        graph[src].append(dest)
    
    visited = bfs(1, graph)
    if visited == set(range(1, N + 1)):
        return 1
    return -1

if __name__ == "__main__":
    print(main())

用dfs

复制代码
#有向图: 邻接表

import collections

def dfs(node, graph, visited):
    if node in visited:
        return
    visited.add(node)

    for nei in graph[node]:
        dfs(nei, graph, visited)
    return visited



def main():
    #读入 K 条边,构建一个 邻接表 graph
    N, K = map(int, input().split())

    graph = collections.defaultdict(list)
    for _ in range(K):
        src, dest = map(int, input().strip().split())
        graph[src].append(dest)
    visited = set()
    dfs(1, graph, visited)
    if visited == set(range(1, N + 1)):
        return 1
    return -1

if __name__ == "__main__":
    print(main())
相关推荐
西洼工作室7 分钟前
python邮箱令牌/点击验证、邮箱验证码实现
前端·python
skywalk816315 分钟前
编程里碰到的柯里化是什么意思?
开发语言
倔强的猴子(翻版)18 分钟前
我用 Python 写了个排序库,一亿数据量下比 C 级 np.sort() 快 7 倍
人工智能·python·算法·阿里云·文心一言
lly20240619 分钟前
Julia 正则表达式
开发语言
郝学胜-神的一滴20 分钟前
深入理解回归损失函数:MSE、L1 与 Smooth L1 的设计哲学
人工智能·python·程序人生·算法·机器学习·数据挖掘·回归
历程里程碑21 分钟前
MySQL数据类型全解析 + 代码实操讲解
大数据·开发语言·数据库·sql·mysql·elasticsearch·搜索引擎
ZC跨境爬虫22 分钟前
Python Django开发者转向微信小程序:从架构理解到第一行代码的完整准备指南
开发语言·python·ui·微信小程序·django
绘梨衣54723 分钟前
django-elasticsearch-dsl-drf 搜索服务搭建教学文档
python·elasticsearch·django
沐知全栈开发24 分钟前
Eclipse 首选项(Preferences)详解
开发语言
测试员周周30 分钟前
【AI测试系统】第6篇:需求扔进去,3 分钟出测试用例?AI测试系统的 RAG 知识增强实战
人工智能·python·功能测试·测试工具·测试用例