python 基础知识点(蓝桥杯python科目个人复习计划37)

今日复习内容:DFS--回溯

1.介绍

回溯:就是DFS是一种,在搜索尝试过程中寻找问题的解,当发现已不满足求解条件时,就“回溯”返回,尝试别的路径。

回溯更强调:此路不通,另寻他路,走过的路需要打标记。

回溯法一般在DFS是基础上加上一些剪枝策略

2.个人理解

我理解的回溯,可以用来求排列

排列要求数字不重复,每次选择的数字都需要打标记,记为vis数组

哟输出当前排列,用于记录路径,记为path数组

简单来说,回溯就是先打标记,记录路径,然后下一层,回到上一层,再清除标记的过程。

我现在把它转化成代码:

def dfs(depth):# 当前为第depth个数字,0到depth - 1已经设置好if depth == n:print(path)return# 枚举第depth个数字for i in range(1,n + 1):# 数字i必须之前没有选择过if vis[i] is False:# 标记当前状态vis[i] = True# 记录当前路径path.append(i)# 进行下一轮搜索dfs(depth + 1)# 清空标记vis[i] = Falsepath.pop(-1)n = int(input('输入一个整数:'))
path = []
vis = [False] * (n + 1)
dfs(0)

运行结果:

回溯还可以用来求子集

给定n个数字,求子集:(我把它写成代码)

# 和买瓜那个题的思路差不多一样
n = int(input("请输入一个数字:"))
a = list(map(int,input().split()))
path = []
def dfs(depth):if depth == n:print(path)return# 该数字被选择的情况下path.append(a[depth])dfs(depth + 1)path.pop(-1)# 若是不选dfs(depth + 1)dfs(0)

运行结果:

例题1:N皇后

题目描述:

在N * N的方格棋盘放置了N个皇后,使得它们不相互攻击(即任意两个皇后不允许处在同一排,同一列,也不允许处在与棋盘边框呈45度角的斜线上) ,你的任务是:对于给定的N,求出有多少种合法的放置方式。

输入描述:

输入中有一个正整数N <= 10,表示棋盘和皇后的数量。

输出描述:

为一个正整数,表示对应输入行的皇后的不同放置数量。

思路:

dfs枚举每一行放置的列;

标记的内容有:每列只能放一个,主对角线:x + y     副对角线:x - y + n

参考答案:

def dfs(depth):if depth == n:global ansans += 1return# 枚举第depth行放在哪列for i in range(1,n + 1):# 坐标为(depth,i)# 第i列先前未选择,主对角线,副对角线都未选择if vis1[i] is False and vis2[depth + i] is False and vis3[depth - i + n] is False:# 标记当前状态vis1[i] = Truevis2[depth + i] = Truevis3[depth - i + n] = Truedfs(depth + 1)# 清除标记vis1[i] = Falsevis2[depth + i] = Falsevis3[depth - i + n] = Falsen = int(input('请输入一个整数:'))
ans = 0
vis1 = [False] * (n  + 1)
vis2 = [False] * (2 * n + 1)
vis3 = [False] * (2 * n + 1)
dfs(0)
print(ans)

运行结果:

例题2:小朋友崇拜圈

题目描述:

班里N个小朋友,每个人都有自己最崇拜的一个小朋友(也可以是自己)。

在一个游戏中,需要小朋友坐一个圈,每个小朋友都有自己最崇拜的小朋友在他的右手边。

求满足条件的圈最大多少人?

小朋友编号1,2,3...N

输入描述:

输入第一行,一个整数N(3 < N < 10^5)

接下来一行N个整数,空格分开。

输出描述:

要求输出一个整数,表示满足条件的最大圈的人数。

思路:

depth(x,length):走到x,已经走了length步

参考答案:

import sys
sys.setrecursionlimit(100000)
def dfs(x,length):# print(x,length)# 记录当前x,已经走了length步vis[x] = length# 如果下一步已经走过,则说明当前已经形成了一个圈if vis[a[x]]:# 更新最大圈global ansans = max(ans,length - vis[a[x] + 1])# 接着走下一步else:dfs(a[x],length + 1)n = int(input('请输入一个整数:'))
a = list(map(int,input().split()))
a = [0] + a
vis = [0] * (n + 1)
ans = 0
for i in range(1,n + 1):if vis[i] == 0:dfs(i,1)
print(ans)

OK,这篇就写到这里 ,下次继续!

ok,这篇就写到这里,下一篇继续!

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

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

相关文章

linux系统下vscode portable版本的c++/Cmake环境搭建001

linux系统下vscode portable版本的Cmake环境搭建 vscode portable 安装安装基本工具安装 build-essential安装 CMake final script code安装插件CMake Tools & cmakeC/C Extension Pack Testsettings,jsonCMakeLists.txt调试和运行工具 CG 目的&#xff1a;希望在获得一个新…

自定义Function MyRandom函数获得随机数

《VBA信息获取与处理》教程(版权10178984)是我推出第六套教程&#xff0c;目前已经是第一版修订了。这套教程定位于最高级&#xff0c;是学完初级&#xff0c;中级后的教程。这部教程给大家讲解的内容有&#xff1a;跨应用程序信息获得、随机信息的利用、电子邮件的发送、VBA互…

手把手教你开发Python桌面应用-PyQt6图书管理系统-图书信息表格数据显示及搜索实现

锋哥原创的PyQt6图书管理系统视频教程&#xff1a; PyQt6图书管理系统视频教程 Python桌面开发 Python入门级项目实战 (无废话版) 火爆连载更新中~_哔哩哔哩_bilibiliPyQt6图书管理系统视频教程 Python桌面开发 Python入门级项目实战 (无废话版) 火爆连载更新中~共计24条视频&…

C++构造和折构函数详解,超详细!

个人主页&#xff1a;PingdiGuo_guo 收录专栏&#xff1a;C干货专栏 大家龙年好呀&#xff0c;今天我们来学习一下C构造函数和折构函数。 文章目录 1.构造函数 1.1构造函数的概念 1.2构造函数的思想 1.3构造函数的特点 1.4构造函数的作用 1.5构造函数的操作 1.6构造函数…

k8s -ingress

概念 Ingress 公开了从集群外部到集群内服务的 HTTP 和 HTTPS 路由&#xff0c;ingress能代理集群为内部的网络&#xff0c;将集群外部的HTTP/HTTPS网络请求转发至不同的service&#xff0c;其本质就是创建一个NodePort类型的svc,和一个nginx 组成 k8s中的ingress 其实是指…

c语言:全局变量与局部变量重名

结论&#xff1a; 作用域小的覆盖作用域大的&#xff0c;顺带一提&#xff0c;在C中&#xff0c;调用全局的变量前面要加:: #include <stdio.h> using namespace std;int a, b; void fun() {a 100;b 200; }int main() {int a 5, b 7;fun();printf("%d %d\n&quo…

Linux操作系统基础(十):Linux系统信息

文章目录 Linux系统信息 一、时间和日期 1、date时间 2、cal日历 二、磁盘、内存信息 Linux系统信息 本篇文章内容主要是为了方便通过远程终端维护服务器时, 查看服务器上当前 系统日期和时间 / 磁盘空间占用情况 /程序执行情况。 学习终端命令都是查询命令, 通过这些命…

假期day7

设计qq界面 代码 ui->lab1->setPixmap(QPixmap(":/pictrue/denglu.webp"));ui->lab1->setScaledContents(true);ui->lab2->setPixmap(QPixmap(":/pictrue/passwd.jpg"));ui->lab2->setScaledContents(true);ui->lab3->setP…

Python API的使用简述

文章目录 Web APIGit 和 GitHub使用 API 调用请求数据安装 requests处理响应 API处理响应字典监视API的速率限制使用 Pygal 可视化仓库改进Pygal图表添加自定义工具提示 本篇文章&#xff1a;我们叙述如何编写一个独立的程序&#xff0c;并对其获取的数据进行可视化。这个程序将…

《统计学简易速速上手小册》第4章:假设检验(2024 最新版)

文章目录 4.1 假设检验的基本概念4.1.1 基础知识4.1.2 主要案例&#xff1a;新饮料偏好测试4.1.3 拓展案例 1&#xff1a;教育方法的效果比较4.1.4 拓展案例 2&#xff1a;工作满意度调查 4.2 常见的假设检验4.2.1 基础知识4.2.2 主要案例&#xff1a;产品包装改进的效果评估4.…

考研数据结构笔记(7)

循环链表、静态链表、顺序表和链表的比较 循环链表循环单链表循环双链表 静态链表什么是静态链表如何定义一个静态链表&#xff1f;简述基本操作的实现 顺序表和链表的比较逻辑结构物理结构/存储结构数据的运算/基本运算创建销毁增加、删除查找 循环链表 循环单链表 循环双链表…

前端JavaScript篇之ajax、axios、fetch的区别

目录 ajax、axios、fetch的区别AjaxAxiosFetch总结注意 ajax、axios、fetch的区别 在Web开发中&#xff0c;ajax、axios和fetch都是用于与服务器进行异步通信的技术&#xff0c;但它们在实现方式和功能上有所不同。 Ajax 定义与特点&#xff1a;Ajax是一种在无需重新加载整个…

2023年全国职业院校技能大赛软件测试赛题第3套

2023年全国职业院校技能大赛 软件测试赛题第3套 赛项名称&#xff1a; 软件测试 英文名称&#xff1a; Software Testing 赛项编号&#xff1a; GZ034 归属产业&#xff1a; 电子与信息大类 …

第2集《佛说四十二章经》

请大家打开讲议第二面&#xff0c;二、经文大意。 在正式讲解经文之前&#xff0c;先说明本经的修学纲要。本经的经文大意共分三段&#xff0c;第一段是总标&#xff0c;第二段是别明&#xff0c;第三段是结劝。总标又分两小段&#xff0c;先看第一小段。 是经顿渐兼收。首唱…

抛弃Spring Cloud Gateway,得物 使用Netty架构100Wqps网关

说在前面 在40岁老架构师 尼恩的读者交流群(50)中&#xff0c;很多小伙伴拿到一线互联网企业如阿里、网易、有赞、希音、百度、滴滴的面试资格。 最近&#xff0c;尼恩指导一个小伙伴简历&#xff0c;写了一个《高并发网关项目》&#xff0c;此项目帮这个小伙拿到 字节/阿里/…

洛谷p3435 OKR-Periods of Words

题目链接 反思 我们之前用 k m p kmp kmp都是用到前缀字串的最长匹配长度&#xff0c;本题则需要利用 p m t pmt pmt数组找到最短匹配长度 思路 题目中匹配前缀的意思是&#xff0c;在字符串 a a a的前缀中&#xff0c;某个前缀自身重复两遍后能把 a a a包括进来 如图&…

【Linux】make和Makefile

目录 make和Makefile make和Makefile 我们使用vim编辑器的时候&#xff0c;在一个文件里写完代码要进行编译&#xff0c;要自己输入编译的指令。有没有一种可以进行自动化编译的方法——makefile文件&#xff0c;它可以指定具体的编译操作&#xff0c;写好makefile文件&#x…

Hive窗口函数详解

一、 窗口函数知识点 1.1 窗户函数的定义 窗口函数可以拆分为【窗口函数】。窗口函数官网指路&#xff1a; LanguageManual WindowingAndAnalytics - Apache Hive - Apache Software Foundationhttps://cwiki.apache.org/confluence/display/Hive/LanguageManual%20Windowing…

奶茶点餐|奶茶店自助点餐系统|基于微信小程序的饮品点单系统的设计与实现(源码+数据库+文档)

奶茶店自助点餐系统目录 目录 基于微信小程序的饮品点单系统的设计与实现 一、前言 二、系统功能设计 三、系统实现 1、商品信息管理 2、商品评价管理 3、商品订单管理 4、用户管理 四、数据库设计 1、实体ER图 2、具体的表设计如下所示&#xff1a; 五、核心代码 …

云计算运维 · 第三阶段 · 代码上线案例

学习b记 第三阶段 持续集成案例 这一章做一个小的案例&#xff0c;git、gitlab、jenkins、sonarqube、maven、shell把这周学的一整个流程串联起来做一个完整的代码发布流程案例&#xff0c;这一部分东西比较多&#xff0c;相对于之前的笔记这个会做的仔细一点。#嘿嘿回家就是…