zoukankan      html  css  js  c++  java
  • BFS

    2017-07-25 21:40:22

    writer:pprp

    在DFS的基础上加上了一个BFS函数

    #include <iostream>
    #include <queue>
    
    using namespace std;
    
    const int N = 9;
    
    queue<int> qu;
    
    int visited[N] = {0};    //新引入一个数组,用于标记是否访问过
    
    struct node
    {
        int vertex;
        node*next;
    };
    
    node head[N];
    
    void BFS(int vertex)              // 宽度优先搜素
    {
          node*point;
          qu.push(vertex);
          visited[vertex] = 1;
          cout<< vertex <<"->";
          while(!qu.empty())
          {
                vertex = qu.front();
                qu.pop();
                point = head[vertex].next;
                while(point!=NULL)
                {
                      if(visited[point->vertex] == 0)
                      {
                            qu.push(point->vertex);
                            visited[point->vertex] = 1;
                            cout <<point->vertex<<"->";
                      }
                      point = point->next;
                }
          }
    }
    
    void create(int val1,int val2)
    {
        node*point;
        node*nnew = new node();
        nnew->vertex = val2;
        nnew->next = NULL;
        point = &head[val1];
        while(point->next!=NULL)
        {
            point = point->next;
        }
        point->next = nnew;
    }
    
    
    void print()
    {
        node*point;
        for(int i = 0; i < N; i++)
        {
            point = head[i].next;
            cout << "Head["<<i<<"]";
            while(point!=NULL)
            {
                cout <<"-> "<<point->vertex;
                point = point->next;
            }
            cout << endl;
        }
    }
    
    int main()
    {
        int node1,node2;
        
        for(int i = 0; i < N; i++)
        {
            head[i].vertex = i;
            head[i].next = NULL;
        }
        while(1)
        {
            cout <<"please enter the start point" << endl;
    
            cin >> node1;
            if(node1 == -1)
                break;
            cout <<"please enter the end point" << endl;
            cin >> node2;
    
            if(node1 == node2)
                cout <<"自身循环"<<endl;
            else if(node1>=N||node2>=N)
                cout <<"超出范围"<<endl;
            else
                create(node1,node2);
        }
    
        cout << "邻接表为:" << endl;
        print();
        
    
        
        cout <<"
    "<<endl;
        
        cout <<"BFS: "<<endl;
        
        BFS(1);
    
        return 0;
    }
  • 相关阅读:
    html标签笔记
    C语言中的函数基础
    数组
    循环控制结构程序(goto、while、dowhile、 for)
    if语句+switch
    分支程序设计
    字符数据的输入与输出
    各类数值型数据之间的混合运算
    c语言概述及如何上机运行c程序
    [记录] Ubuntu 配置Apache虚拟站点
  • 原文地址:https://www.cnblogs.com/pprp/p/7236735.html
Copyright © 2011-2022 走看看