zoukankan      html  css  js  c++  java
  • 广度优先搜索

    广度优先搜索小技巧

    • 使用bool inq(in queue)来记录某一节点是不是入过队(而不是是否被访问)

    矩阵的块 求给定的矩阵中块的个数

    BFS解法

    #include<queue>
    #include<iostream>
    using namespace std;
    int X[] = { 0,0,1,-1 };
    int Y[] = { 1,-1,0,0 };
    const int max_x=30;
    const int max_y=30;
    bool inq[max_x][max_y] = { 0 };
    int val[max_x][max_y];
    struct point {
    	int x;
    	int y;
    };
    queue<point>q;
    int x, y;
    int cnt=0;
    void BFS(int a,int b)
    {
    	point* t = new point;
    	t->x = a;
    	t->y = b;
    	q.push(*t);
    	inq[a][b] = true;
    	point p;
    	while (!q.empty())
    	{
    		p = q.front();
    		q.pop();
    		//添加上下左右
    		if (val[p.x][p.y] == 1)
    		{
    			for (int i = 0; i < 4; i++)
    			{
    				int m = p.x + X[i], n = p.y + Y[i];
    				if (m >= 0 && m < x &&
    					n >= 0 && n < y)
    				{
    					if (!inq[m][n])
    					{
    						t = new point;
    						t->x = m;
    						t->y = n;
    						q.push(*t);
    						inq[m][n] = true;
    					}
    				}
    			}
    		}
    	}
    }
    int main()
    {
    	scanf("%d%d", &x, &y);
    	for (int i = 0; i < x; i++)
    	{
    		for (int j = 0; j < y; j++)
    		{
    			scanf("%d", &val[i][j]);
    		}
    	}
    	for (int i = 0; i < x; i++)
    	{
    		for (int j = 0; j < y; j++)
    		{
    			if (!inq[i][j])
    			{
    				if (val[i][j] == 1)
    				{
    					cnt++;
    					BFS(i,j);
    				}
    			}
    		}
    	}
    	printf("%d", cnt);
    }
    

    DFS解法

    //求给定的矩阵中块的个数
    #include<queue>
    #include<iostream>
    using namespace std;
    int X[] = { 0,0,1,-1 };
    int Y[] = { 1,-1,0,0 };
    const int max_x=30;
    const int max_y=30;
    bool isvisited[max_x][max_y] = { 0 };
    int val[max_x][max_y];
    struct point {
    	int x;
    	int y;
    };
    queue<point>q;
    int x, y;
    int cnt=0;
    void DFS(int a,int b)
    {
    	isvisited[a][b] = true;
    	//如果上下左右是1,访问
    	for (int i = 0; i < 4; i++)
    	{
    		int m = a + X[i], n = b + Y[i];
    		if (m >= 0 && m < x &&
    			n >= 0 && n < y)
    		{
    			if (val[m][n] == 1)
    			{
    				if (!isvisited[m][n])
    					DFS(m, n);
    			}
    		}
    	}
    }
    int main()
    {
    	scanf("%d%d", &x, &y);
    	for (int i = 0; i < x; i++)
    	{
    		for (int j = 0; j < y; j++)
    		{
    			scanf("%d", &val[i][j]);
    		}
    	}
    	for (int i = 0; i < x; i++)
    	{
    		for (int j = 0; j < y; j++)
    		{
    			if (!isvisited[i][j])
    			{
    				if (val[i][j] == 1)
    				{
    					cnt++;
    					DFS(i, j);
    				}
    			}
    		}
    	}
    	printf("%d", cnt);
    }
    
  • 相关阅读:
    Comet OJ
    LOJ#2719. 「NOI2018」冒泡排序 DP+组合+树状数组
    LuoguP6747 『MdOI R3』Teleport 二进制+贪心
    LuoguP6748 『MdOI R3』Fallen Lord 树形DP+set
    LuoguP5576 [CmdOI2019]口头禅 后缀树+线段树+暴力
    LOJ#3161. 「NOI2019」I 君的探险 整体二分+随机化+二进制分组
    LOJ#2085. 「NOI2016」循环之美 莫比乌斯反演+杜教筛
    LuoguP5327 [ZJOI2019]语言 线段树合并+树链求并
    【考试题
    ELK
  • 原文地址:https://www.cnblogs.com/code-fun/p/15224754.html
Copyright © 2011-2022 走看看