Python DFS基础例题:全排列问题、最大连通

全排列问题

按照字典序输出自然数 1 1 1 到 n n n 所有不重复的排列,即 n n n 的全排列,要求所产生的任一数字序列中不允许出现重复的数字。

输入格式

一个整数 n n n。
输出格式

由 1 ∼ n 1 \sim n 1∼n 组成的所有不重复的数字序列,每行一个序列。

每个数字保留 5 5 5 个场宽。
样例输入

复制代码
3

样例输出

复制代码
	1    2    3
    1    3    2
    2    1    3
    2    3    1
    3    1    2
    3    2    1

提示
1 ≤ n ≤ 9 1 \leq n \leq 9 1≤n≤9。
解题思路

代码:

python 复制代码
"""
"""
n = int(input())
x = [0] * (n + 1) # 1-n
vis = [0] * (n + 1) # 标记
d = [0] * (n + 1) # 当前排列的数组
for i in range(1, n + 1):
    x[i] = i 

def dfs(step):
    if step == n + 1:# 如果长度已经最大,则输入当前的序列 d
        for i in range(1, n + 1):
            print('%5d'%d[i],end='')
        print()
        return
    for i in range(1, n + 1):
        if vis[i] == 0: # 如果该标记为0,则认为还没有走过这歌分支
            d[step] = x[i]
            vis[i] = 1 # 将该位置标记为1,后续暂时不走(保留现场)
            dfs(step + 1) # 继续走下一步
            vis[i] = 0 # 恢复现场,后续可以继续使用
    return

dfs(1)

最大连通

题目链接:最大连通(蓝桥)

解题思路

定义四个方向,x和y的,然后开始寻找,如果当前值为0,那么返回0,表示走不通。如果是1的话,将当前的元素置为0,表示已经走过,然后依次寻找四个方向,继续做深度优先遍历。如果遇到边界情况要进行判断,之后进行累加连通的块数即可。

python 复制代码
n, m = 30, 60
# dx, dy为四个方向
dx = [-1, 0, 1, 0]
dy = [0, 1, 0, -1]

def dfs(x, y):
    if g[x][y] == '0':  return 0 # 如果为0,则该地方走不通
    g[x][y] = '0'
    cnt = 1 #记录连通分块数
    for i in range(4):
        nx = x + dx[i]
        ny = y + dy[i]
        if nx < 0 or nx >= n or ny < 0 or ny >= m:  continue
        cnt += dfs(nx, ny)
    return cnt

# 获取输入
g = list()
for i in range(n):
    g.append(list(input().strip()))
print(g)

ans = 0
for i in range(n):
    for j in range(m):
        if g[i][j] == '1':
            ans = max(ans, dfs(i,  j))
print(ans)
相关推荐
C嘎嘎嵌入式开发2 小时前
(2)100天python从入门到拿捏
开发语言·python
Stanford_11062 小时前
如何利用Python进行数据分析与可视化的具体操作指南
开发语言·c++·python·微信小程序·微信公众平台·twitter·微信开放平台
white-persist4 小时前
Python实例方法与Python类的构造方法全解析
开发语言·前端·python·原型模式
Java 码农4 小时前
Centos7 maven 安装
java·python·centos·maven
格林威4 小时前
常规线扫描镜头有哪些类型?能做什么?
人工智能·深度学习·数码相机·算法·计算机视觉·视觉检测·工业镜头
倔强青铜三5 小时前
苦练Python第63天:零基础玩转TOML配置读写,tomllib模块实战
人工智能·python·面试
浔川python社5 小时前
《网络爬虫技术规范与应用指南系列》(xc—3):合规实操与场景落地
python
B站计算机毕业设计之家5 小时前
智慧交通项目:Python+YOLOv8 实时交通标志系统 深度学习实战(TT100K+PySide6 源码+文档)✅
人工智能·python·深度学习·yolo·计算机视觉·智慧交通·交通标志
IT森林里的程序猿5 小时前
基于机器学习方法的网球比赛胜负趋势预测
python·机器学习·django
正牌强哥6 小时前
Futures_ML——机器学习在期货量化交易中的应用与实践
人工智能·python·机器学习·ai·交易·akshare