盲目搜索算法(DFS、BFS、DFS-ID)
admin
2024-02-16 05:21:52
0

目录

概念

BFS

DFS

DFS-ID


概念

盲目搜索算法指的是不使用领域知识的不知情搜索算法。主要包括三种算法:深度优先搜索(DFS)广度优先搜索(BFS)迭代加深(DFS-ID)的深度优先搜索

当树很深、分支因子不大、在树中解出现的位置相对较深时,选择深度优先搜索。

当搜索树的分支因子不太大、在树中解出现的位置在合理的深度级别、路径不是非常深的时候,选择广度优先搜索。

在深度优先和广度优先的基础上,结合二者形成了一种全新的算法:迭代加深的深度优先

PS: 简单的说就是不断扩大搜索深度的深度优先。

使用DFS-ID若没有找到目标,就会执行另一个DFS,深度界限为1,每次迭代深度界限加1,搜索都要重新开始。

BFS是完备和优选的(在各种约束下),但过量的空间需求使其在应用上受到阻碍。

DFS既不是完备也不是优选的,DFS可能变得非常长或迷失在无限的路径中,但是空间需求合理。

DFS-ID同时具备DFS和BFS的有利性,即DFS的合理空间以及BFS的完备和优选,但是每次深度更新都需要把之前探索过的路径重新探索一遍,会存在非常大的时间浪费。

BFS

思路

BFS和DFS都需要准备一个close 标志,表示哪些点已经走过了,不需要再走了,也叫visit 图。

BFS 的基本逻辑就是,遍历周边的4个点,然后把4个点都放在队列里,然后出队首,重新把新的节点的周围4个点放进去,直到遍历到结束点。

代码

#define MaxSize 1000// 边节点
typedef struct ANode
{// 边所指的终点顶点int adjvex;// 下一条边,邻域,指向下一个邻接点struct ANode * nextarc;// 权值int weight;
}ArcNode;// 顶点
typedef struct Vnode
{// 数据域int data;	// 指向的第一条边ArcNode * firstarc;
}VNode;// 邻接表
typedef struct
{VNode adjlist[MaxSize];// n为顶点数,e为边数int n;int e;	
}Graph;// G为邻接点指针,V为初始访问节点
void BFS(Graph * G, int v)
{// 边节点ArcNode * p;// 访问数组int visited[MaxSize];// 队列int Qu[MaxSize];// 初始化循环队列int front = 0, rear = -1;// 当前节点的下标int w;// 初始化访问数组for(int i = 0; i < G->n; i++){visited[i] = 0;}// 访问第一个节点printf("%d\n", v);visited[v] = 1;// 第一个节点入队rear = (rear + 1) % MaxSize;Qu[rear] = v;// 开始广度优先遍历while(front != rear){front = (front + 1) / MaxSize;// 出队w = Qu[front];// 使p指向顶点的第一个边节点p = G->adjlist[w].firstarc;// 循环访问完w的所有边节点while(p != NULL){if(visited[p->adjvex] == 0){// 访问节点printf("%d\n", p->adjvex);visited[p->adjvex] = 1;// 入队rear = (rear + 1) % MaxSize;Qu[rear] = p->adjvex;}p = p -> nextarc;}}}

DFS

思路

深度优先算法的核心是栈,就是说把一个点周围4个节点先放在栈里,然后出栈顶,重新把周围的4个节点放在栈里,直到找到结束点。

代码

//利用C++实现深度优先搜索算法,如有疑问请联系
//作者:cclplus 邮箱:maxwell970710@gmail.com
#include
#include
#include
#includeusing namespace std;vector> tree;//声明一个二维向量
int flag[10];//用于搜索到了节点i的第几个节点
stack stk;//声明一个堆栈
int ar_tree[8] = { 1,1,1,3,5,3,5,7 };
void DFS(int node) {cout << node <<" ";if (flag[node] == 0) {stk.push(node);}int temp;//判断node的子节点是否搜索完成if (flag[node] < tree[node].size()) {temp = tree[node][flag[node]];flag[node]++;DFS(temp);}else {//若已经完成stk.pop();//弹出子节点if (!stk.empty()) {//若堆栈不为空temp = stk.top();//取此时的栈顶元素,即为node的上一级节点DFS(temp);}}
}
int main() {ios::sync_with_stdio(false);memset(flag, 0, sizeof(flag));register int i,temp;tree.resize(10);//图中的数共有九个节点//生成树for (i = 2; i <=9; i++) {temp = ar_tree[i - 2];tree[temp].push_back(i);//表示第i个节点为第temp个节点的子节点}//DFScout << "DFS过程:" << endl;DFS(1);cout << endl;return 0;
}

DFS-ID

思路

所谓深度迭代,就是设置一个深度tag,一旦超过该深度就不再将新节点入栈,如果没有找到结束节点就深度tag++,然后重来一遍。

代码

bool DLS(GrapheMat* graphe, Node* source, NomSom but, int limit) {bool found = false;printf("%s\n", (char*)source->etat);if (strcmp((char*)source->etat, (char*)but) == 0) {return true;}if (limit > 0) {List* listSon = nodeSon(graphe, source);while(!listEpmty(listSon)) {Node* son = (Node*)popList(listSon);if (DLS(graphe, son, but, limit-1)) {return true;}}}return false;
}bool IDDLS (GrapheMat* graphe, NomSom goal, int limit) {bool found = false;node* source = createNode(graphe, graphe->nomS[0]);for (int i = 0; i <= limit; i++) {printf("/nLimit : %d\n", i);DLS(graphe, source, goal, i);}return false;
}

相关内容

热门资讯

斗金订购APP贵金属期货投资被...   斗金订购APP的投资者被广告宣传给诱导,注册就送什么现金,然后充值返现金卷等等这些宣传方式,都是...
哈易购APP非法期货交易欺骗投...   哈易购APP宣传可做白银铂金贵金属订购交易,但实际上并没有取得相关交易资质!哈易购APP本质上就...
消息称百度旗下昆仑芯瞄准500... 6 月 29 日消息,据《The Information》昨日援引知情人士消息,百度旗下 AI 芯片...
打造夏日消费新场景 第35届北... 北京商报讯(记者 翟枫瑞)6月29日消息,第35届北京国际燕京啤酒文化节新闻发布会在京举行。本届啤酒...
社保基金持仓数据出炉,一季度增... 最近各大上市公司一季度财报都公开了,咱们国家社保基金的持仓数据也全部曝光。目前社保拿着比亚迪价值44...
36氪首发 | 海思、中兴团队... 作者 | 乔钰杰 编辑 | 袁斯来 硬氪获悉,广州宸思通讯科技有限公司(以下简称“宸思科技”)近日完...
两天蒸发47亿市值!一纸税务通... 一纸税务通知书,能让一家百亿龙头两天蒸发47亿市值。 6月22日,北大荒(600598.SH)公告称...
SK海力士将投资1100万亿韩... SK集团会长崔泰源6月29日在韩国“三大重大计划”发布会上宣布,公司将投资1100万亿韩元扩大半导体...
两只A股,终止上市! 两家A股公司,即将摘牌。 6月29日,退市沪科(600608.SH)公告称,上海证券交易所将在202...
原创 M... 一家成立近十年的自动驾驶公司,在IPO时吸引了14家基石投资者认购近一半的发行股份,其中不乏奔驰、比...
基金忠言|国寿安保滤镜碎,三年... 图片来源:视觉中国 蓝鲸新闻6月29日讯(记者 祁和忠)保险系基金公司国寿安保总经理换人了。 6月2...
三星电机计划加码玻璃基板!相关... 6月29日,玻璃基板概念股午后有所回升, 华工科技(000988.SZ)逼近涨停, 彩虹股份(600...
拉萨海关持续壮大外贸经营主体 ...   新华网拉萨6月28日电(记者蒋梦辰)近日,记者从拉萨海关获悉,今年前5个月,西藏有进出口实绩的外...
机构:二季报临近,医药生物板块... 6月29日,华源证券发布了一篇医药生物行业的研究报告,报告指出,业绩期临近,产业链景气度有望再次迎来...
每日收评科创50放量涨超4.5... 财联社6月29日讯,三大指数全线收红,创业板指探底回升,科创50指数大涨4.61%。沪深两市成交额3...
6月多地土拍结构性升温:深圳单... 进入2026年6月,不少城市核心区地块集中诞生高溢价宗地,热度突出的城市包含深圳、杭州、长沙。 其中...
业绩炸裂!盛达资源半年预盈3.... 6月29日,贵金属矿山龙头盛达资源(000603.SZ)发布 2026 年半年度业绩预告,上半年业绩...
A股午后拉升三大股指收涨:半导... A股三大股指6月29日开盘涨跌互现。早盘沪强深弱,创指一度跌超2%。半导体午后拉升,带动两市上涨,沪...
原创 空... 前言 大家好,我是老金。 这几天,两幅极度割裂的画面放在一起,把我看笑了。 一边是在持续的热浪下,欧...