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

今日复习计划:DFS搜索基础

1.简介

搜索方法:穷举问题解空间部分(所有情况),从而求出问题的解。

深度优先搜索:本质上是暴力枚举

深度优先:尽可能一条路走到底,走不了再回退。

2.DFS和n重循环

给定一个数字x,将其拆分成3个正整数,后一个要求大于等于前一个,给出方案。

最简单的思想:三重循环暴力求解。

若是拆分成n个正整数,就需要实现n重循环

n重循环 = 特定的树状结构 = DFS搜索

举个例子:

给定一个数字6,将其 拆分成3个正整数,后一个要求大于等于前一个,给出方案。

将其拆分成3个正整数,当然需要3重循环

第一层:0 

第二层:1 2 3 4 5 6

第三层:6组1 2 3 4 5 6,分别连接第二层的每个数字

这就是我们上数学时经常画的树状结构图。

n重循环,同样的道理

给定一个数字x,将其 拆分成n个正整数,后一个要求大于等于前一个,给出方案。

需要n重循环,也就是需要n层树状结构

用DFS:从上往下找一条合法的路径,所谓合法,就是要满足路径值不递减,长度为n,和为x三个条件。

我来把它转化成代码:

def dfs(depth):
    # depth:表示当前处于第depth层
    # 递归出口
    if depth == n:
        # 判断数字是否递增
        for i in range(1,n):
            if path[i] >= path[i - 1]:
                continue
            else:
                return
        if sum(path) != x:
            return
        # 这才是我们要的答案
        print(path)
        return
    # 对于每一层,枚举当前拆出的数字
    for i in range(1,x + 1):
        path[depth] = i # 当前层拆出了一个i,记录上去
        dfs(depth + 1)

x = int(input())  # 题目给的数字
n = int(input())  # 需要拆分成n重循环
# path = [i]  # 表示第i个数字,给path一个初始值
path = [0] * n
dfs(0)

运行结果:

 

当然了,可以优化:

def dfs(depth,last_value):
    # depth:表示当前处于第depth层
    # 递归出口
    if depth == n:
        if sum(path) != x:
            return
        # 这才是我们要的答案
        print(path)
        return
    # 对于每一层,枚举当前拆出的数字
    for i in range(last_value,x + 1):
        path[depth] = i # 当前层拆出了一个i,记录上去
        dfs(depth + 1,i)

x = int(input('输入题中的数字:'))  # 题目给的数字
n = int(input('请输入题目要求要拆分成几重循环:'))  # 需要拆分成n重循环
# path = [i]  # 表示第i个数字,给path一个初始值
path = [0] * n
dfs(0,0)

运行结果:

 

 这里的区别是:(我举个例子)

给定一个数字6,将其 拆分成3个正整数,后一个要求大于等于前一个,给出方案。

将其拆分成3个正整数,当然需要3重循环

第一重:0

第二重:1 2 3 4 5 6

第三重:1 2 3 4 5 6(对应数字1) 2 3 4 5 6(对应数字2)3 4 5 6(对应数字3)

               4 5 6(对应数字4)5 6(对应数字5)6(对应6)

就是把不必要的分支去掉了,类似于《运筹学》中“分支定界法”的“减支”这一步骤

例题1:分糖果

题目描述:

两种糖果分别于9个和16个,,要全部分给7个小朋友,每个小朋友得到的糖果总数最少为2个最多为5个,问有多少种不同的分法,且糖果必须全部分完。

只要有其中一个小朋友在两种方案中分到的糖果不完全相同,这两种方案就算两种不同的方案。

答案提交:

这是一道结果填空的题,你只需要算出结果都提交即可。本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

思路:

用7重循环,每重循环代表一个小朋友,每个小朋友枚举自己的糖果情况。

参考答案:

ans = 0
def dfs(depth,n,m):
    # depth:第depth个小朋友
    # n:第一种糖果的剩余量
    # m:第二种糖果的剩余量
    # 递归出口
    if depth == 7:
        if n == 0 and m == 0:
            global ans
            ans += 1
        return
    # 接下来枚举每个小朋友的情况
    # 第一种糖果的情况
    for i in range(0,6):
        # 因为每个人最多5个糖果
        # 第二种糖果的情况
        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)

运行结果:

 

例题2:买瓜

题目描述:

小蓝正在一个瓜摊上买瓜,瓜摊上共有n个瓜,每个瓜的质量为Ai。

小蓝刀工了得,他可以把任何瓜劈成等重的两份,不过每个瓜只能劈一刀,小蓝希望买到的瓜的重量的和恰为m。

请问小蓝至少要劈多少个瓜才能买到质量恰好为m的瓜。

如果怎样小蓝都无法得到总重恰好为m的瓜,请输出-1。

输入描述:

输入的第一行包含两个整数n,m,用一个空格分开,分别表示瓜的个数和小蓝想买到的瓜的总重量。

第二行包括n个整数Ai,相邻整数之间用空格分隔,分别表示每个瓜的重量。

输出描述:

输出一个整数,表示答案。

思路:

n重循环,每重循环3种情况:买一个,买一半,不买。

参考答案:

def dfs(depth,weight,cnt):
    if weight > m:
        return
    if weight == m:
        global ans
        ans = min(ans, cnt)
    if depth == n:

        return
    # 枚举当前3种情况
    dfs(depth + 1,weight + 0,cnt)
    dfs(depth + 1,weight + A[depth],cnt)
    dfs(depth + 1,weight + A[depth] // 2,cnt + 1)

n,m = map(int,input().split())
m *= 2
A = list(map(int,input().split()))
A = [x * 2 for x in A]
ans = n + 1
dfs(0,0,0)
if ans == n + 1:
    ans = -1

print(ans)

运行结果:

 

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

(若有不懂的地方,可以互相交流) 


 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

《统计学简易速速上手小册》第6章:多变量数据分析(2024 最新版)

文章目录 6.1 主成分分析&#xff08;PCA&#xff09;6.1.1 基础知识6.1.2 主要案例&#xff1a;客户细分6.1.3 拓展案例 1&#xff1a;面部识别6.1.4 拓展案例 2&#xff1a;基因数据分析 6.2 聚类分析6.2.1 基础知识6.2.2 主要案例&#xff1a;市场细分6.2.3 拓展案例 1&…

Linux--目录结构

目录 一、Linux的目录结构二、常用的目录介绍 一、Linux的目录结构 Linux的目录结构是一个树型结构。 Windos 系统可以拥有多个盘符&#xff0c;如C盘&#xff0c;D盘,E盘。 Linux 木有盘符这个概念&#xff0c;只有一个根目录 /&#xff08;相当于文件夹&#xff09;&#xf…

快速幂的应用

1.非递归的解法 #include <iostream> using namespace std; int main(){int a,b,c,t1;cin>>a>>b>>c;if(a>2&&a<1e3&&b>0&&a<1e7&&c>2&&c<1e5)for(int i0;i<b;i)tt*a%c;cout<<t;r…

Keil : Error-Flash Download failed Cortex-M4错误

1.打开魔术棒 2.点击Debug设置 3.查看是否有你使用的板子型号的flash 4.如果没有的话就添加以下

备份还原实际操作

备份还原实际操作 前言 根据达梦文档整理。 一、工具介绍 工具联机/脱机工具应用场景disql联机1️⃣数据库备份2️⃣归档备份3️⃣表空间备份与还原4️⃣表备份与还原dmrman脱机1️⃣数据库备份、还原和恢复2️⃣脱机还原表空间3️⃣归档的备份、还原和修复manager联机对应…

leetcode(矩阵)74. 搜索二维矩阵(C++详细解释)DAY7

文章目录 1.题目示例提示 2.解答思路3.实现代码结果 4.总结 1.题目 给你一个满足下述两条属性的 m x n 整数矩阵&#xff1a; 每行中的整数从左到右按非严格递增顺序排列。每行的第一个整数大于前一行的最后一个整数。 给你一个整数 target &#xff0c;如果 target 在矩阵中…

Hadoop-Yarn-ResourceManagerHA

在这里先给屏幕面前的你送上祝福&#xff0c;祝你在未来一年&#xff1a;技术步步高升、薪资节节攀升&#xff0c;身体健健康康&#xff0c;家庭和和美美。 一、介绍 在Hadoop2.4之前&#xff0c;ResourceManager是YARN集群中的单点故障 ResourceManager HA是通过 Active/St…

python+flask+django农产品供销展销电子商务系统lkw43

供销社农产品展销系统的设计与实现&#xff0c;最主要的是满足使用者的使用需求&#xff0c;并且可以向使用者提供一些与系统配套的服务。本篇论文主要从实际出发&#xff0c;采用以对象为设计重点的设计方法&#xff0c;因此在进行系统总体的需求分时借助用例图可以更好的阐述…

备战蓝桥杯---搜索(进阶4)

话不多说&#xff0c;直接看题&#xff1a; 下面是分析&#xff1a; (ab)%c(a%cb%c)%c; (a*b)%c(a%c*b%c)%c; 因此&#xff0c;如果两个长度不一样的值%m为相同值&#xff0c;那就舍弃长的&#xff08;因为再加1位只不过是原来值*10那位值&#xff0c;因此他们得出的%m还是同…

【Effective Objective - C 2.0】——读书笔记(二)

文章目录 前言六、理解“属性”这一概念七、在对象内部尽量直接访问实例变量八、理解“对象等同性”这一概念九、以“类族模式”隐藏实现细节十、在既有类中使用关联对象存放自定义数据十一、理解objc_msgSend的作用十二、理解消息转发机制动态方法解析备援接受者完整的消息转发…

PE 特征码定位修改程序清单 uiAccess

requestedExecutionLevel level"asInvoker" uiAccess"false" 可以修改这一行来启用禁用原程序的盾牌图标&#xff0c;似乎作用不大。以前没事写的一个小玩意&#xff0c;记录一下。 等同于这里的设置&#xff1a; 截图 代码如下&#xff1a; #include …

mac卸载被锁定的app

sudo chflags -hv noschg /Applications/YunShu.app 参考&#xff1a;卸载云枢&#xff08;MacOS 版&#xff09;

Java 学习和实践笔记(6)

各数据类型所占的空间&#xff1a; byte: 1个字节 short&#xff1a;2个字节 int&#xff1a;4个 long&#xff1a;8个 float&#xff1a;4个 double: 8个 char:1个 boolean:1bit 所有引用数据类型都是4个字节&#xff0c;实际其值是指向该数据类型的地址。 上图中稍特…

【iOS】——使用ZXingObjC库实现条形码识别并请求信息

文章目录 前言一、实现步骤二、扫描界面和扫描框的样式1.扫描界面2.扫描框 三、实现步骤 前言 ZXing库是一个专门用来解析多种二维码和条形码&#xff08;包括包括 QR Code、Aztec Code、UPC、EAN、Code 39、Code 128等&#xff09;的开源性质的处理库&#xff0c;而ZingObjC库…

单片机学习笔记---AT24C02(I2C总线)

目录 有关储存器的介绍 存储器的简介 存储器简化模型 AT24C02介绍 AT24C02引脚及应用电路 I2C总线介绍 I2C电路规范 开漏输出模式和弱上拉模式 其中一个设备的内部结构 I2C通信是怎么实现的 I2C时序结构 起始条件和终止条件 发送一个字节 接收一个字节 发送应答…

Failed to construct ‘RTCIceCandidate‘ sdpMid and sdpMLineIndex are both null

最近在搞webrtc&#xff0c;在编写函数处理远端传递来的candidate时报错了&#xff0c;具体信息如下。国内关于webrtc的资料很少&#xff0c;所以去国外社区转了一圈&#xff0c;回来记录一下报错的解决方案 其实这个bug也好解决&#xff0c;根据报错信息可以判断是RTCIceCand…

【数据库】Unlogged 表使用

【数据库】Unlogged 表使用 前言普通表和Unlogged 表的写性能比较普通表创建和数据插入Unlogged 表创建和数据插入比较结果 Unlogged 表崩溃和正常关闭测试Unlogged 表特点总结 前言 大神偶像在开会上提及了Unlogged 表&#xff0c;它的特点很不错&#xff0c;很适合实时数据保…

图(高阶数据结构)

目录 一、图的基本概念 二、图的存储结构 2.1 邻接矩阵 2.2 邻接表 三、图的遍历 3.1 广度优先遍历 3.2 深度优先遍历 四、最小生成树 4.1 Kruskal算法 4.2 Prim算法 五、最短路径 5.1 单源最短路径-Dijkstra算法 5.2 单源最短路径-Bellman-Ford算法 5.3 多源最…

代码随想录算法训练营第四十九天(动态规划篇之01背包)| 474. 一和零, 完全背包理论基础

474. 一和零 题目链接&#xff1a;https://leetcode.cn/problems/ones-and-zeroes/submissions/501607337/ 思路 之前的背包问题中&#xff0c;我们对背包的限制是容量&#xff0c;即每个背包装的物品的重量和不超过给定容量&#xff0c;这道题的限制是0和1的个数&#xff0…

C语言学习记录

小飞机_牛客题霸_牛客网 (nowcoder.com) 飞机翅膀12个*&#xff0c;第一行按5下空格&#xff0c;再按两下*&#xff0c;再按5下空格&#xff0c;最后一行按4下空格&#xff0c;再按一下*&#xff0c;再按两下空格&#xff0c;再按一下*&#xff0c;再按4下空格 数格子就完了&a…
最新文章