蓝桥杯(3):python搜索DFS

 

目录

1 DFS简介

1.1 DFS与n重循环

1.2 代码实现

1.3 例题

1.3.1 分糖果

1.3.2 买瓜

2 回溯

2.1 定义

2.2 代码实例

2.1.1 排列数

 2.1.2 找子集

2.3 例题

2.3.1 N皇后

2.3.2 小朋友崇拜圈

2.3.3 全球变暖

3 剪枝

3.1 定义

3.2 分类

3.3 例子

3.3.1 数字王国之军训练队

3.3.2 特殊的多边形

4 记忆化搜索

4.1 定义

4.2 例子

4.2.1 斐波那契数列

4.2.2 混沌之地

4.2.3 地宫取宝


1 DFS简介

1.1 DFS与n重循环

DFS 就是枚举 和n重循环

1.2 代码实现

#dfs和n重循环
x = int(input())
n = int(input())
path = [0]*n
#depth从0开始哦!!!def dfs(depth):#depth表示当前的深度!#采用递归的思想#写递归出口if depth == n:for i in range(1,n):if path[i] >= path[i-1]:continueelse:returnif sum(path) != x:returnprint(path)returnelse:for i in range(1,x+1):path[depth] = idfs(depth+1)dfs(0)

1.3 例题

1.3.1 分糖果

#糖果总数
#一共有7个小朋友,9个第一种糖果,16个第二种糖果
ans = 0
def dfs(depth,n,m):#depth当前是第几个小朋友#n表示剩余几个第一种#m表示剩余几个第二种if depth == 7:if n==0 and m==0:global ansans +=1# print(ans)returnelse:for i in range(0,6):for j in range(0,6):if 2<=i+j<=5 and i <=n and j<=m:dfs(depth+1,n-i,m-j)dfs(0,9,16)
print(ans)

1.3.2 买瓜

#买瓜def dfs(depth,weight,cnt):#depth表示第depth个瓜#weight表示当前的重量#cnt表示砍了几刀if weight > m:returnif weight == m:global ansans = min(ans,cnt)if depth == n:returnelse:#买全部dfs(depth+1,weight+a[depth],cnt)#卖一半dfs(depth+1,weight+a[depth]//2,cnt+1)#没买dfs(depth+1,weight,cnt)n,m = list(map(int,input().split()))
a = list(map(int,input().split()))
weight = 0
cnt = 0
m*=2
a = [i*2 for i in a]
ans = n+1
dfs(0,0,0)if ans == n+1:ans = -1print(ans)

2 回溯

2.1 定义

2.2 代码实例

2.1.1 排列数

回溯:判断是否能选、打标记、记录路径、下一层、回到上一层??(是怎么回去的啊老铁)清楚标记、清楚路径储存

回到上一层:通过debug我得出:回到上一层其实是递归自己过程中的实现

递归会造成多个函数的运行,只有运行完才会结束!语言描述能力有限,具体可以自己debug一下感受

n = int(input())
vis = [False]*(n+1)
path = []def dfs(depth):if depth == n:print(path)returnelse:for i in range(1,n+1):if vis[i]: #如果已经被标记过就不选这个数直接跳出循环!continuevis[i] = Truepath.append(i)dfs(depth+1)vis[i] = Falsepath.pop(-1)dfs(0)

 2.1.2 找子集

和买瓜一样,瓜是这个瓜买不买,

子集是,这个数选不选   一模一样!!!哦哦哦

找到人任意集合的所有子集

#求子集
#和卖瓜的一样
n = int(input())
a = list(map(int,input().split()))path = []def dfs(depth):if depth ==n:print(path)returnelse:#选的话path.append(a[depth])# print(path)dfs(depth+1)path.pop(-1)#不选的话dfs(depth+1)
dfs(0)

2.3 例题

2.3.1 N皇后

不能在同一行同一列和对角线上

# N皇后
#主要是对角线的处理,如果在主对角线上 横纵坐标的值相加为0,在副对角线上横纵坐标相减为0
n = int(input()) #表示有几个皇后
ans = 0
vis1 = [False]*(n+1)
vis2 = [False]*2*(n+1)
vis3 = [False]*2*(n+1)def dfs(x): #x表示第几行if x==n:global ansans +=1returnelse:for y in range(0,n):#判断是否能放if vis1[y] is False and vis2[x+y] is False and vis3[x-y+n] is False:vis1[y] = vis2[x+y] = vis3[x-y+n] = Truedfs(x+1)vis1[y] = vis2[x + y] = vis3[x - y+n] = Falseelse:continuedfs(0)
print(ans)

2.3.2 小朋友崇拜圈

就是要围成一个圈!图论的知识相关

从1出发 开始找环,length用于记录步长--走到之后判断是否可以走,如果不可以走说明到了原来走过的点了

#小朋友崇拜环
import sys
sys.setrecursionlimit(10000000) #例如这里设置为十万
def dfs(x,length):#从x出发找环#length走了多少步vis[x] = length  #这个点走了一步现在#接下来走下面的点了if vis[a[x]] != 0:#说明在a[x]这一点形成环了,那么这个点出的length值应该是第一步!global ansans = max(ans,length - vis[a[x]] +1)return#说明下一个点已经走过了#这时就要输出环长了else:#说明可以走dfs(a[x], length+1) #步长加1n = int(input())
a = [0] + list(map(int,input().split()))
vis = [0]*(n+1) #标记该点是否走过
ans = 0
an = []for i in range(1,n+1):dfs(i,1)
print(ans)

2.3.3 全球变暖

高地:上下左右都是#

对于每一个#都看看是不是高地

思路:

1、从左到右 从上到下,对于未标记的陆地“#”做一遍dfs

2、dfs目的:拓展可以到达的所有点,并打上标记

3、可以统计出有多少个岛屿、有多少个高地(上下左右都是#)

#全球变暖
import sys
sys.setrecursionlimit(10000000) #例如这里设置为十万def dfs(x,y):#表示现在搜索的点的坐标#标记该点vis[x][y]=1#判断是不是高低if a[x-1][y] == "#" and a[x+1][y] == "#" and a[x][y-1] == "#" and a[x][y+1] == "#" :#说明上下左右都是高低不会被淹没global flagflag = True#把四周的未遍历的土地继续遍历!!!!!!!#所有连在一起的就是一座岛屿#这个坐标周围如果还有陆地说明他们是一个岛屿 没有结束,接着运行!!!!!!!!!!!!for i in range(4):xx,yy = x+dir[i][0],y+dir[i][1]if 0<=xx <=n-1 and 0<= yy<=n-1:if a[xx][yy] == "#" and vis[xx][yy] == 0:dfs(xx,yy)else:continue#先写输入
dir = [(1,0),(0,1),(-1,0),(0,-1)]
n = int(input())
a = []
vis = [] #表示标记
flag = False#表示是否是高地!
for i in range(n):a.append(list(input()))vis.append([0]*n)ans = 0
for i in range(n):for j in range(n):if a[i][j] == "#" and vis[i][j] == 0:flag = Falsedfs(i,j)if flag is False:ans += 1
print(ans)

3 剪枝

3.1 定义

当前状态无解就不要向下搜索了

3.2 分类

3.3 例子

3.3.1 数字王国之军训练队

把学生分组:

则dfs的参数就是学生

#数字王国之军训练队
#学生分成多少组?--学生————所以depth是学生
n = int(input())
a = list(map(int,input().split()))
group = []def check(x,group):for y in group:if x%y==0 or y%x== 0 or x==y:return Falsereturn Truedef dfs(depth):if depth == n:global ansans = min(ans,len(group))# print(group)return ans#放入已有的组中for ever_group in group:if check(a[depth],ever_group):ever_group.append(a[depth])dfs(depth+1)ever_group.pop(-1)#自己变成一个组group.append([a[depth]])dfs(depth+1)group.pop(-1)#最后要输出一个最小组数
ans = n
dfs(0)
print(ans)

3.3.2 特殊的多边形

#剪枝-特殊的多边形
import sys
sys.setrecursionlimit(100000) #例如这里设置为十万
t,n = list(map(int,input().split()))
a = []
for i in range(t):a.append(list(map(int,input().split())))
# print(a)def dfs(depth,last_i,tot,mul,list):if depth == n:if tot > 2*path[-1] and list[0] <= mul <= list[1]:global ansans += 1# print(path)returnelse:for i in range(last_i+1,100001):if mul*(i**(n-depth)) <= list[1]:path.append(i)dfs(depth+1,i,tot+i,mul*i,list)path.pop(-1)else:breakfor list in a:path = []ans = 0dfs(0,1,0,1,list)print(ans)

4 记忆化搜索

4.1 定义

4.2 例子

4.2.1 斐波那契数列

考虑使用递归写法,直接递归的时间是指数级别增加的

重复计算的地方发在字典里!

#斐波那契数列
#没有存储的写法
def f(n):if n==0:return 1if n==1:return 1else:return f(n-1)+f(n-2)
n = int(input())
print(f(n))#存储的写法dict={0:1,1:1}
def f(n):if n in dict.keys():return dict[n]else:dict[n] = f(n-1)+f(n-2)return dict[n]
print(f(40))

但是有一个更牛*的

记忆化搜索的第二种方法

#实现把普通的递归变成记忆化的递归
from functools import lru_cache
@lru_cache(maxsize=None)
def f(n):if n==0:return 1if n==1:return 1else:return f(n-1)+f(n-2)
n = int(input())
print(f(n))

4.2.2 混沌之地

dfs的参数确定 :坐标

from functools import lru_cache
@lru_cache(maxsize=None)
def dfs(x,y,z):#x,y 表示当前的坐标#z表示喷气背包有没有用if x == c and y==d:return Trueelse:for detle_x,detle_y in [(0,1),(1,0),(-1,0),(0,-1)]:xx = x+detle_xyy = y+detle_yif 0<=xx<=n-1 and 0<=yy<=m-1:if A[xx][yy] <A[x][y]:dfs(xx,yy,z)if A[xx][yy] <A[x][y]+k and z==False:dfs(xx,yy,True)return False#输入
n,m,k = list(map(int,input().split()))
a,b,c,d = list(map(int,input().split()))
a -=1
b -=1
c -=1
d -=1A = []
for i in range(n):A.append(list(map(int,input().split())))#输出
out = dfs(a,b,False)
if out == True:print("Yes")
else:print("No")'''
5 5 30
1 1 5 5
3 20 13 12 11
19 17 33 72 10
12 23 12 23 9
21 43 23 12 2
21 34 23 12 1
'''

4.2.3 地宫取宝

####当没有不使用记忆搜素,并且加入的是当前位置的val值时

def dfs(x,y,tot,w)  :  #在(x,y)的数量tot,最大价值为wif x==n and y==m :global ansif tot==k:ans +=1returnreturnfor delta_x,delta_y in [(0,1),(1,0)]:xx,yy=x+delta_x,y+delta_yif 0<=xx<=n and 0<=yy<=m:if w < val[xx][yy]: #把上一个位置的value加进去了dfs(xx,yy,tot+1,val[xx][yy])dfs(xx, yy, tot, w)  # 不选择else:continuereturnn,m,k=map(int,input().split())
val=[[0]*(m+1)]
for i in range(n):val.append([0]+list(map(int,input().split())))
print(val)ans = 0
dfs(1,1,1,1)
dfs(1,1,0,-1)
print(ans)

###当不使用记忆力搜索,加入的是上一个位置的val值

def dfs(x,y,tot,w)  :  #在(x,y)的数量tot,最大价值为wif x==n and y==m :global ansif tot==k:ans +=1returnelif tot==k-1 and w<val[n][m]:ans+=1returnreturnfor delta_x,delta_y in [(0,1),(1,0)]:xx,yy=x+delta_x,y+delta_yif 0<=xx<=n and 0<=yy<=m:if w < val[x][y]: #把上一个位置的value加进去了dfs(xx,yy,tot+1,val[x][y])dfs(xx, yy, tot, w)  # 不选择else:continuereturnn,m,k=map(int,input().split())
val=[[0]*(m+1)]
for i in range(n):val.append([0]+list(map(int,input().split())))
print(val)ans = 0
dfs(1,1,0,-1)
print(ans)

###当使用记忆力搜索时!!!!【和之前所有的不同的就是return一定要有返回值!!!不能是空了,要不然记忆什么 我请问呢小姐姐】

from functools import lru_cache
@lru_cache(maxsize=None)
def dfs(x,y,tot,w)  :  #在(x,y)的数量tot,最大价值为wif x==n and y==m :if tot==k:return 1elif tot==k-1 and w<val[n][m]:return 1return 0ans =0for delta_x,delta_y in [(0,1),(1,0)]:xx,yy=x+delta_x,y+delta_yif 0<=xx<=n and 0<=yy<=m:if w < val[x][y]: #把上一个位置的value加进去了ans +=dfs(xx,yy,tot+1,val[x][y])ans +=dfs(xx, yy, tot, w)  # 不选择else:continuereturn ansn,m,k=map(int,input().split())
val=[[0]*(m+1)]
for i in range(n):val.append([0]+list(map(int,input().split())))print(dfs(1,1,0,-1))

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

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

相关文章

自动化测试:Selenium中的时间等待

在 Selenium 中&#xff0c;时间等待指在测试用例中等待某个操作完成或某个事件发生的时间。Selenium 中提供了多种方式来进行时间等待&#xff0c;包括使用 ExpectedConditions 中的 presence_of_element_located 和 visibility_of_element_located 方法等待元素可见或不可见&…

javaWeb项目-火车票订票信息系统功能介绍

项目关键技术 开发工具&#xff1a;IDEA 、Eclipse 编程语言: Java 数据库: MySQL5.7 框架&#xff1a;ssm、Springboot 前端&#xff1a;Vue、ElementUI 关键技术&#xff1a;springboot、SSM、vue、MYSQL、MAVEN 数据库工具&#xff1a;Navicat、SQLyog 1、Spring Boot框架 …

任务2.1 一元二次方程(顺序结构版)

在这个任务中&#xff0c;我们编写了一个Java程序来解决一元二次方程。程序接受用户输入的系数a、b、c&#xff0c;并计算出方程的根。通过计算判别式delta的值&#xff0c;我们可以确定方程有两个不相等实根、两个相等实根还是没有实数根。这个程序遵循了IPO模式&#xff0c;即…

MCGS学习——MCGS仿真与实体西门子监控

MCGS仿真与西门子监控 前提知识——博图与MCGS联合仿真 适用于什么设备都没有的情况下进行学习 对NetToPLCsim进行初始设置 找到博图的IP地址 勾选允许远程对象的通信访问 勾选系统时钟参数&#xff0c;主要是需要用到1HZ的脉冲&#xff0c;做一个闪烁的灯 编写简单程序&am…

如何在Linux系统使用Docker本地部署Halo网站并实现无公网IP远程访问

最近&#xff0c;我发现了一个超级强大的人工智能学习网站。它以通俗易懂的方式呈现复杂的概念&#xff0c;而且内容风趣幽默。我觉得它对大家可能会有所帮助&#xff0c;所以我在此分享。点击这里跳转到网站。 文章目录 1. Docker部署Halo1.1 检查Docker版本如果未安装Docker可…

2024/3/28 IOday1

编写一条学生链表&#xff0c;写一些能够像链表里边添加数据的函数 实现&#xff1a;将链表中的所有内容保存到文件中去 以及 读取文件中的所有内容&#xff0c;加载到链表里 #include <stdio.h> #include <string.h> #include <stdlib.h> typedef int datat…

SpringBoot学习之ElasticSearch下载安装和启动(Windows版)(三十)

本文先写windows下的下载安装和启动,后续有时间再补充其他环境下(Mac、Linux、Docker)的,这里我们后续对ElasticSearch简称为ES,读者习惯这一称呼就好。 一,ES下载 可以百度【ElasticSearch官网】或者直接点击这里的ES官网下载地址:​​​​​ Download Elasticsearch…

springboot检测脚本

import requests import urllib3 urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning) session requests.session()# 从文本文件中读取 with open(dic.txt, r) as file:paths file.readlines()# 移除每个末尾的换行符 paths [path.strip() for path in pa…

智慧公厕解决方案打造更加智能的卫生空间

一、智慧公厕方案概述 智慧公厕方案旨在解决现有公厕存在的诸多问题&#xff0c;包括民众用厕困难、环境卫生状况不佳、管理效率低下等方面。针对民众的需求和管理方面的挑战&#xff0c;智慧公厕提供了一套综合解决方案&#xff0c;包括智能导航、环境监测、资源管理等功能&a…

pygame用chatgpt绘制3d沿x轴旋转的

import pygame from pygame.locals import * import sys import mathpygame.init()width, height 800, 600 screen pygame.display.set_mode((width, height))vertices [(0, 100, 0), (100, 200, 0), (300, 100, 0)]angle 0 rotation_speed 2 # 可根据需要调整旋转速度 c…

CXL系统架构

CXL系统架构 CXL支持三种设备类型&#xff0c;如下图。Type 1支持CXL.cache和CXL.io&#xff1b;Type 2支持CXL.cache&#xff0c;CXL.mem和CXL.io&#xff1b;Type 3支持CXL.mem和CXL.io。无论哪种类型&#xff0c;CXL.io都是不可缺少的&#xff0c;因为设备的发现&#xff0…

图像处理与视觉感知---期末复习重点(5)

文章目录 一、膨胀与腐蚀1.1 膨胀1.2 腐蚀 二、开操作与闭操作 一、膨胀与腐蚀 1.1 膨胀 1. 集合 A A A 被集合 B B B 膨胀&#xff0c;定义式如下。其中集合 B B B 也称为结构元素&#xff1b; ( B ^ ) z (\hat{B})z (B^)z 表示 B B B 的反射平移 z z z 后得到的新集合。…

MySQl基础入门 ⑮

上一遍文章内容 使用语句创建视图 还是用上次的三个表&#xff0c;如果没有创建&#xff0c;点击上一遍文章内容创建即可。 什么叫视图 视图是一个或多个表中导出来的表&#xff0c;它是一种虚拟存在的表&#xff0c;并且表的结构数据都依赖基本表&#xff0c;通过视图不仅…

js改变图片曝光度(高亮度)

方法一&#xff1a; 原理&#xff1a; 使用canvas进行滤镜操作&#xff0c;通过改变图片数据每个像素点的RGB值来提高图片亮度。 缺点 当前项目使用的是svg&#xff0c;而不是canvas 调整出来的效果不是很好&#xff0c;图片不是高亮&#xff0c;而是有些发白 效果 代码 …

鸿蒙OS开发实例:【工具类封装-首选项本地存储】

import dataPreferences from ohos.data.preferences; import bundleManager from ohos.bundle.bundleManager; 本地首选项数据的保存&#xff0c;利用key value 【使用要求】 DevEco Studio 3.1.1 Release api 9 【使用示例】 1、app启动时&#xff0c;从本地读取数据&…

Linux文件(系统)IO(含动静态库的链接操作)

文章目录 Linux文件&#xff08;系统&#xff09;IO&#xff08;含动静态库的链接操作&#xff09;1、C语言文件IO操作2、三个数据流stdin、stdout、stderr3、系统文件IO3.1、相关系统调用接口的使用3.2、文件描述符fd3.3、文件描述符的分配规则3.3、重定向3.4、自制shell加入重…

Docker 夺命连环 15 问

目录 什么是Docker&#xff1f; Docker的应用场景有哪些&#xff1f; Docker的优点有哪些&#xff1f; Docker与虚拟机的区别是什么&#xff1f; Docker的三大核心是什么&#xff1f; 如何快速安装Docker&#xff1f; 如何修改Docker的存储位置&#xff1f; Docker镜像常…

三位数组合-第12届蓝桥杯选拔赛Python真题精选

[导读]&#xff1a;超平老师的Scratch蓝桥杯真题解读系列在推出之后&#xff0c;受到了广大老师和家长的好评&#xff0c;非常感谢各位的认可和厚爱。作为回馈&#xff0c;超平老师计划推出《Python蓝桥杯真题解析100讲》&#xff0c;这是解读系列的第42讲。 三位数组合&#…

揭露非法集资陷阱!

常见的非法集资手法 犯罪分子利用了社会公众的哪些心理&#xff1f; 使用了怎样的措辞&#xff1f; 一起来揭露非法资金集聚的几个陷阱&#xff01; 拐弯抹角地向亲朋好友承诺大额回报&#xff0c;希望他们加入&#xff08;利用社会认同原则&#xff09;。 不法分子造了个传…

精灵传信系统 匿名性系统 支持网站+小程序双端源码

精灵传信支持在线提交发送短信&#xff0c;查看回复短信&#xff0c;在线购买额度&#xff0c;自定义对接易支付&#xff0c;设置违禁词&#xff0c;支持网站小程序双端。 项目 地 址 &#xff1a; runruncode.com/php/19720.html 环境要求: PHP > 73 MySQL>5.6 Ngi…