当前位置: 首页 > news >正文

河源哪有做网站店铺100个关键词

河源哪有做网站,店铺100个关键词,网页设计的几种版式,万能小偷程序做网站双向广搜 定义 双向广度优先搜索(Bi-directional Breadth-First Search, Bi-BFS)是一种在图或树中寻找两点间最短路径的算法。与传统的单向广度优先搜索相比,它从起始点和目标点同时开始搜索,从而有可能显著减少搜索空间&#x…

双向广搜

定义

双向广度优先搜索(Bi-directional Breadth-First Search, Bi-BFS)是一种在图或树中寻找两点间最短路径的算法。与传统的单向广度优先搜索相比,它从起始点和目标点同时开始搜索,从而有可能显著减少搜索空间,提高搜索效率,特别是在处理大规模图或者寻找最短路径时更为明显。

运用情况

  1. 最短路径问题:当需要快速找到两个节点间的最短路径时,特别是路径非常长或者图非常大的情况下,双向BFS比单向BFS更高效。
  2. 有界搜索问题:在一些问题中,比如迷宫求解,我们知道起始点和终点,且关心的是尽快相遇而不是探索整个图,这时双向BFS非常适用。
  3. 游戏AI:在某些游戏中,为了快速计算玩家与目标之间的最短路径,可以使用双向BFS。
  4. 网络路由:在网络通信中寻找最短的路由路径时,也可以应用此算法。

注意事项

  1. 相遇判断:当两个搜索的前沿相遇时,需要确保正确识别并停止搜索,避免重复计算。
  2. 路径合并:找到相遇点后,需要合并两个方向的路径以得到完整的最短路径。
  3. 空间复杂度:虽然可以减少搜索的深度,但同时维护两个队列(或集合)可能会增加额外的空间消耗。
  4. 平衡问题:为了优化性能,需要尽量保持两个方向的搜索速度平衡,可以通过调整每一步扩展的节点数来实现。

解题思路

  1. 初始化:设置两个队列,一个用于存储从起点出发的节点,另一个用于存储从终点出发的节点。同时,为两个方向的节点分别标记已访问状态,防止重复访问。
  2. 广度优先遍历:同时进行两个方向的广度优先遍历。每次遍历时,从两个队列中各取出一层的节点进行扩展,并将新扩展的节点加入到相应的队列中。
  3. 检查相遇:在扩展节点的过程中,检查是否有节点已经被另一个方向访问过。如果发现这样的节点,说明找到了一条从起点到终点的路径,此时停止搜索。
  4. 路径合并:从相遇节点开始,逆向追踪标记,直到回到起点或终点,这样就可以得到完整的最短路径。
  5. 优化策略:根据具体问题,可能需要考虑启发式信息、队列管理策略等进一步优化搜索过程。

AcWing 190. 字串变换

题目描述

190. 字串变换 - AcWing题库

运行代码

#include <iostream>
#include <cstring>
#include <algorithm>
#include <queue>
#include <unordered_map>using namespace std;const int N = 6;int n;
string A, B;
string a[N], b[N];int extend(queue<string>& q, unordered_map<string, int>&da, unordered_map<string, int>& db, string a[N], string b[N])
{int d = da[q.front()];while (q.size() && da[q.front()] == d){auto t = q.front();q.pop();for (int i = 0; i < n; i ++ )for (int j = 0; j < t.size(); j ++ )if (t.substr(j, a[i].size()) == a[i]){string r = t.substr(0, j) + b[i] + t.substr(j + a[i].size());if (db.count(r)) return da[t] + db[r] + 1;if (da.count(r)) continue;da[r] = da[t] + 1;q.push(r);}}return 11;
}int bfs()
{if (A == B) return 0;queue<string> qa, qb;unordered_map<string, int> da, db;qa.push(A), qb.push(B);da[A] = db[B] = 0;int step = 0;while (qa.size() && qb.size()){int t;if (qa.size() < qb.size()) t = extend(qa, da, db, a, b);else t = extend(qb, db, da, b, a);if (t <= 10) return t;if ( ++ step == 10) return -1;}return -1;
}int main()
{cin >> A >> B;while (cin >> a[n] >> b[n]) n ++ ;int t = bfs();if (t == -1) puts("NO ANSWER!");else cout << t << endl;return 0;
}

代码思路

  1. 输入处理:首先读取起始字符串A和目标字符串B,然后逐行读取变换规则(子串A[i]到B[i]的变换)直到文件结束。

  2. 双端BFS:算法采用了双端BFS策略,即同时从字符串A和B出发,试图找到两者之间的最短变换路径。使用两个队列qaqb分别存储从A和B出发的可能状态,以及两个哈希表dadb记录每个状态到起点的距离。

  3. 扩展函数:定义了extend函数,用于从一个队列中取出所有状态并尝试应用所有变换规则,扩展出新的状态加入队列,并更新距离哈希表。这个函数是BFS的关键,它确保每次扩展只增加一步操作。

  4. 主循环:在主循环中交替从两端扩展,直到找到变换路径或者达到最大步数限制。

  5. 结果判断:最后,根据搜索结果输出最少步数或"No Answer!"。

改进思路

  1. 减少重复计算:当前代码在扩展状态时,对每个状态与每条规则都进行了匹配尝试,这可能会导致大量重复计算,尤其是在规则较多或字符串较长时。可以通过维护一个已访问状态的集合来避免重复探索相同的状态。

  2. 规则预处理:为了提高效率,可以在开始搜索之前对变换规则进行预处理,比如建立一个从子串到新子串的直接映射,这样在扩展状态时可以直接查找而无需遍历所有规则。

  3. 剪枝:在双向BFS中,当从两端搜索的边界状态的距离之和已经大于当前最小步数时,可以提前终止搜索,这是一种有效的剪枝策略。

  4. 内存使用优化:考虑使用更节省空间的数据结构,比如使用滚动数组或者动态调整容器大小来减少内存占用。

http://www.shuangfujiaoyu.com/news/48627.html

相关文章:

  • 万州房产网站建设网络营销的公司有哪些
  • 大型网站开发实战精准广告投放
  • 程序外包网seo查询seo
  • 建设银行短信带网站十大成功营销策划案例
  • 北京市建设厅网站2345网址导航电脑版官网
  • 作网站莆田关键词优化报价
  • 做网站好的网站建设公司排名检测网站是否安全
  • 哪些网站做耽美谷歌play
  • 福田专业做网站公司百度seo怎么做网站内容优化
  • wordpress url神马快速排名优化工具
  • 如何制作收费网站google官网入口手机版
  • ios移动网站开发seo综合查询工具下载
  • 做旅游的网站的要素站长数据
  • 网站开发跟网页制作山西优化公司
  • 个人备案可以建企业网站吗湖南手机版建站系统开发
  • 珠海pc网站建设企业网址
  • 模板网站建设开发软件开发
  • 北京软装设计公司有哪些seo网站快排
  • 个人网站的制作步骤seo推广代运营
  • 做软件项目需不需要有网站营销推广怎么做
  • 中国做的手机系统下载网站优化推广网站怎么做最好
  • 外贸网站建设推广公司网站推广的主要方式
  • centos wordpressseo的名词解释
  • 佛山百度seo点击软件windows优化大师可靠吗
  • 怎么弄 一个空间放两个网站 用不同的域名广告位招商怎么找客户
  • 公司网站制作价格营销组合策略
  • 开发网站和app推广之家app
  • 百度wap关键词整站优化
  • 服装外贸网站设计百度指数查询工具
  • wordpress会务网站模版深圳网站设计实力乐云seo