【数据结构(邓俊辉)学习笔记】图05——优先级搜索

文章目录

  • 0. 概述
  • 1. BAG
  • 2. ADT

0. 概述

学习下优先级搜索

1. BAG

在这里插入图片描述
优先级搜索是非常广义的,概况来说,无论DFS 还是BFS从逻辑上来都属于这种搜索。

回忆下什么叫搜索或者遍历,对于像图这种数据结构里的元素逐一的没有重复的也没有遗漏的对它们进行访问,在不同的应用问题里,这种访问其实最最重要的是次序,怎么确定次序?
~  
以前在初级的数据结构,比如向量或者列表为代表,那种次序取决于结构本身的,它的结构是线性的,从头到尾从左到右一个一个访问过去就可以,线性在数学里是有很多含义在里面,既可以认为它有这种前驱后继,线性还有一些意思——是否显示的可以预测的。
~  
很多问题经常可以听到这是个非线性问题,什么叫非线性问题,说穿了就是在处理这个问题的时候,几乎只能用一种边走边看的策略,不可能一眼看穿,虽然心里知道在数学上肯定是确定的,但是它不会那么显示的更不会那么简明的给出这个次序,所以大概是一种摸着石头过河,慢慢地,走一步算一步。在这样一种非线性情况下,更重要的是通过一种策略来确定一种次序,比如可行的一种策略是:遍历到第k步,已经有k个元素被访问过了,那么第k+1个是谁?如果有一种策略,根据彼时彼刻地场景,能够确定下一个是谁,那不就可以了嘛。

在这里插入图片描述
优先级搜索PFS中重要的当然是优先级,它大概来说是借用某一种数据结构来处理这种东西的,这种数据结构笼统叫做BAG。

就像书包一样,所有的元素(红色的)一开始都在包里面,接下来会有一个访问完了的容器,它们中间会有一根线,这个线很重要,表示是访问完了的还是没有访问的,假设已经有部分元素访问完了(蓝色的),那么现在最核心的问题就是接下来要挑谁?
~  
这个所谓的第k+1个到底是谁,如果能够确定,对它进行访问并把它挪过来。如果有这个简明的策略,可以持续的反复的不断的进行操作,这不就是一个遍历的算法嘛。
~  
实际上,所有的东西从这个方向来审视都可以化为一个复杂的那样过程,但是每次都是一个很简明的策略,它其实都是去解释BAG中所有的元素各自的优先级。这个策略变得这么简单了,于是这个问题就转化为最最重要的BAG是什么,其实不同的BAG就会导致不同的优先级分配,当然也包括选取。

概括下所谓的PFS就是用某种数据结构把这些元素组织起来并且每个元素分配一个优先级,接下来过程每次都是做一个selection,选出来并标记为visited,接下来repeat,知道BAG耗尽。

2. ADT

在这里插入图片描述
对一个图的pfs,方法也是从任何一个点开始,通过迭代或递归做下去,这个过程是非线性,非线性允许这些元素的private会有所变化,所以必然有更新private的过程,这里把更新优先级的过程使用函数对象写出来,首先初始化s状态值,while中每次都找出最高优先级元素,把它摘出来并作访问。

while怎么作?
在这里插入图片描述
前面两行就是update priority。

每个元素优先级如果有改变的话,只有一个机会,当有一个元素这里取s被选出并访问,有些节点会占它的光,有机会提升它的优先级,这些节点就是它的邻居。对它的每一个相邻元素这里取w取出来,更新器priUpdater策略——(this)依据当前这幅图,如果确认s刚刚被访问过,它的邻居w便有机会update,具体的update依据算法而异。

update后,接下来select 出最高优先级元素

for循环虽然看起来复杂但活做的简单,就是从一个预设的开始,对于所有UNDISCOVERED的点(BAG中的元素)进行比较并更新优先级并记下对象。

选出来后,将这个点加入到已选的BAG中

这里借助函数对象prioUpdater,使算法设计者得以根据不同的问题需求,简明地描述和实现对应的更新策略。具体地,只需重新定义prioUpdater对象即可,而不必重复实现公共部分。比如,此前的BFS搜索和DFS搜索都可按照此模式统一实现。

后面,以最小支撑树和最短路径这两个经典的图算法为例,深入介绍这一框架的具体应用。

  1. 复杂度

在这里插入图片描述

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

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

相关文章

360数字安全:2024年4月勒索软件流行态势分析报告

勒索软件传播至今,360 反勒索服务已累计接收到数万勒索软件感染求助。随着新型勒索软件的快速蔓延,企业数据泄露风险不断上升,勒索金额在数百万到近亿美元的勒索案件不断出现。勒索软件给企业和个人带来的影响范围越来越广,危害性…

基于微信小程序的智能校园导览系

基于微信小程序的智能校园导览系统 一、项目概述 背景: 随着高校信息化建设的推进,校园导览服务成为提升师生校园生活便利性的重要一环。 微信小程序因其轻量级、即用即走的特点,成为校园导览服务的理想选择。 目标: 开发一款功能全面、界面友好、操作简便的基于微信小…

第一百零二节 Java面向对象设计 - Java静态内部类

Java面向对象设计 - Java静态内部类 静态成员类不是内部类 在另一个类的主体中定义的成员类可以声明为静态。 例子 以下代码声明了顶级类A和静态成员类B: class A {// Static member classpublic static class B {// Body for class B goes here} }注意 静态成…

基于神经网络的股票K线数据预测未来涨幅

本文介绍了一种基于全连接神经网络(Fully Connected Network, FCN)的股票K线数据预测策略。具体步骤包括数据预处理、模型构建与训练、以及模型的验证和预测。 数据预处理 数据预处理是时间序列预测中的关键步骤。我们从历史K线数据中提取特征并生成标…

python实现将excel数据指保存到word表格中

准备一个excel表格 上代码: import openpyxl from docx import Document# 读取Excel文件 excel_file 大学名次.xlsx wb openpyxl.load_workbook(excel_file) ws wb.active# 获取Excel文件中的所有工作表名称 sheet_names wb.sheetnames# 遍历每个工作表&#x…

ipynb转markdown的简单方法

在线转换 推荐在线转换,拖进去后下载就行,简单易操作。 Convert Jupyter notebook to GitHub-Flavored Markdown for free on AlldocsThe free text converter for all your documents.https://alldocs.app/convert-jupyter-notebook-to-markdown vsc…

Web前端不挂科:深入探索与实战指南

Web前端不挂科:深入探索与实战指南 在数字化时代的浪潮中,Web前端开发已成为一项炙手可热的技能。然而,对于许多初学者来说,如何避免在Web前端课程中挂科却成为了一道难题。本文将从四个方面、五个方面、六个方面和七个方面&…

6_1 Linux 用户管理

6_1 Linux 用户管理 文章目录 6_1 Linux 用户管理[toc]1. 用户管理2. 组账户3. 本地账户数据文件4. 用户账号创建与删除5. 设置密码6. 用户初始配置文件7. 组账户管理8. 总结 1. 用户管理 用户管理的作用:可以登入操作系统;不同的用户有不同的权限唯一标…

设备安装施工的一点总结

下工厂安装了几百台设备,总结一点经验。 信号强度造成设备不稳定 设备是使用物联网卡的联网设备,以前一直用的是单天线(虽然设计上可以接四根天线),没发现什么问题,但是这一批硬件设计有改动,稳…

PyTorch 开发环境快速安装

PyTorch 开发环境快速安装包含三大步骤,具体如下: Anaconda 图文安装教程链接 # 安装时会自带 Python conda info # 使用该命令在终端验证是否安装成功CUDA 图文安装教程链接 nvcc -v # 使用该命令在终端验证是否安装成功PycharmPyTorch 图…

双指针数组问题

删除有序数组中的重复项 重点在于p1 class Solution {public int removeDuplicates(int[] nums) {if(nums.length0) return 0;int p10,p21;while(p2<nums.length){if(nums[p2]!nums[p1]){nums[p1]nums[p2];}else p2;}return p11;} } class Solution {public void moveZeroe…

kv视频如何转码mp4格式,kv转换mp4最简单方法

在数字化时代&#xff0c;视频格式转换成为了一项日常需求。有时候我们需要把kv格式转换为MP4格式。下面将详细介绍kv转MP4的方法 方法一、 1、使用 "小白兔视频格式在线转换网站" 2、地址发给"小白兔视频格式在线转换网站"的客服&#xff0c;客服下载即可…

堆排序要点和难点以及具体案例应用

堆排序(Heap Sort)是一种基于堆数据结构的排序算法。下面我将以分点表示和归纳的方式,结合相关数字和信息,详细描述堆排序的PTA(Programming and Testing Approach,编程与测试方法)。 1. 堆排序原理 堆排序是一种树形选择排序,利用了完全二叉树的性质,通过构建最大堆…

【数据结构(邓俊辉)学习笔记】图06——最小支撑树

文章目录 0. 概述1. 支撑树2. 最小支撑树3. 歧义性4. 蛮力算法5. Prim算法5.1 割与极短跨越边5.2 贪心迭代5.3 实例5.4 实现5.5 复杂度 0. 概述 学习下最小支撑树和prim算法。 1. 支撑树 最小的连通图是树。 连通图G的某一无环连通子图T若覆盖G中所有的顶点&#xff0c;则称…

(delphi11最新学习资料) Object Pascal 学习笔记---第14章泛型第2节(泛型类型实例化)

14.2.3 泛型类型实例化 ​ 请注意&#xff0c;这是一个相当高级的一节内容&#xff0c;重点关注泛型的一些内部细节及其潜在的优化。如果这是您第一次学习泛型&#xff0c;那么建议您多读一遍。 ​ 除了一些优化之外&#xff0c;每次实例化泛型类型时&#xff0c;无论是在方法…

[沉迷理论]进制链表树

往期文章推荐&#xff1a; 题解之最大子矩阵-CSDN博客 洛谷P1115最大子段和[神奇的题目]-CSDN博客 &#xff08;一条神奇的分割线&#xff09; 前言 好久没有更新的我总算在百忙之中抽出时间写了篇博客。 最近总算结束了动态规划的学习&#xff0c;真的是头昏脑涨啊。 最…

45.django - 开始建立第一个项目

1.django是什么&#xff1f; Django是一个高级的、免费的、开源的Web应用框架&#xff0c;它由Python编程语言编写而成。Django遵循模型-视图-控制器&#xff08;MVC&#xff09;的设计模式&#xff0c;但通常将其称为模型-视图-模板&#xff08;MVT&#xff09;架构。它的主要…

Silanna UV光荣推出了一款革命性的高功率远紫外线LED

这款令人瞩目的光源&#xff0c;拥有令人震撼的235nm波长&#xff0c;并被巧妙地封装在紧凑的6.8mm结构中&#xff0c;其魅力与实力兼具。 今年六月&#xff0c;在苏格兰圣安德鲁斯大学举行的盛大2024年远紫外科学和技术国际大会&#xff08;ICFUST&#xff09;上&#xff0c;S…

华为坤灵路由器配置telnet

在用户视图下执行命令install feature-software WEAKEA安装弱安全算法/协议特性包&#xff08;WEAKEA&#xff09;。配置Telnet服务器的管理网口IP地址。 <HUAWEI> system-view [HUAWEI] sysname Telnet Server [Telnet Server] interface meth 0/0/0 [Telnet Server-ME…

[一] 解释自己思维判断与行为 - 《情报分析心理学》读后感

读后记第一篇 以下大部分内容并非直接来自翻译&#xff0c;均为笔者学习阅读后书面、口述语言 我们将通过未曾接触过的情报分析心理学 认知心理学角度上认识并解释自己 前言 网络安全与情报学的融合 花了一周多的时间学习完了《情报分析心理学》&#xff0c;正如书中所讲的…