首页 > 其他分享 >邻接表存储实现图的深度优先遍历

邻接表存储实现图的深度优先遍历

时间:2022-12-05 16:00:11浏览次数:53  
标签:存储 遍历 int next ch 邻接 find 输入

编写程序,实现由邻接表存储实现无向图的深度优先搜索遍历的功能。顶点为字符型。

输入格式:

第一行输入顶点个数及边的个数,第二行依次输入各顶点,第三行开始依次输入边的两个顶点,用空格分开。最后输入深度优先遍历的起始点。

输出格式:

输出深度优先遍历结果,空格分开,若起始点不合理,则输出error。

输入样例:

在这里给出一组输入。例如:

8 9
0 1 2 3 4 5 6 7
0 1
0 2
1 3
1 4
2 5
2 6
3 7
4 7
5 6
0

输出样例:

在这里给出相应的输出。例如:

0 2 6 5 1 4 7 3 
#include<iostream>
#include<cstdio>
using namespace std;
struct edge{
    int v;
    edge* next;
};
struct node{
    char val;
    edge* next;
}a[1010];
int n;
 
int find(char ch){
    for(int i=0;i<n;i++){
        if(a[i].val==ch){
            return i;
        }
    }
    return -1;
}
 
void add(int u,int v){
    edge* e=new edge();
    e->next=a[u].next;
    e->v=v;
    a[u].next=e;
}
 
bool st[1010];
void dfs(int u){
    cout<<a[u].val<<' ';
    st[u]=1;
    edge* e=a[u].next;
    while(e!=NULL){
        if(st[e->v]==0){
            dfs(e->v);
        }
        e=e->next;
    }
}
 
int main(){
    int m;
    cin>>n>>m;
     
    for(int i=0;i<n;i++){
        char ch;
        cin>>ch;
        a[i].val=ch;
    }
     
    for(int i=0;i<m;i++){
        char u,v;
        cin>>u>>v;
        int uu=find(u),vv=find(v);
        add(uu,vv);
        add(vv,uu);
    }
     
    char ch;
    cin>>ch;
    int k;
    if((k=find(ch))!=-1){
        dfs(k);
    }else{
        cout<<"error";
    }
     
    return 0;
}

  

 

标签:存储,遍历,int,next,ch,邻接,find,输入
From: https://www.cnblogs.com/yitongtianxia666/p/16952551.html

相关文章

  • k8s配置存储(ConfigMap、Secret)
    配置存储ConfigMapConfigMap是一种比较特殊的存储卷,它的主要作用是用来存储配置信息的。创建configmap.yaml,内容如下:apiVersion:v1kind:ConfigMapmetadata:nam......
  • mysql的varchar最大能存储多少个字符?
    mysql中varchar能够存储可变长度的字符串。过去我做的诸多业务中,一般存储短字符串的需求,都会使用varchar类型,并且定义长度为255,也就是varchar(255)。不过为了探究varchar......
  • 大数据时代:如何节省存储成本
    现今的科技发展日新月异。尤其是存储方面,表现的极其突出。从技术、用户和应用方面来看,其发展速度超越了其他IT领域。同时也带来了相应的问题。数据中心和企业的管理者们都......
  • 每日算法之二叉搜索树的后序遍历序列
    JZ33二叉搜索树的后序遍历序列描述输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则返回true,否则返回false。假设输入的数组的任意两个数......
  • 为什么要用存储过程
    为什么要用存储过程几个去IBM面试的兄弟回来抱怨:去了好几个不同的IBM项目组,几乎每个面试官问到数据库的时候都要问用没用过存储过程,烦人不?大家去面的程序员,又不是DBA,......
  • 监控库中存储和函数变更记录存储
    监控库中存储和函数变更记录存储1、建表createtableetl_logselectnow()etl_time,routine_typeobject_type,specific_nameobject_na......
  • 《不用编程,不用遍历》 回复
    《不用编程,不用遍历》     https://tieba.baidu.com/p/8172829227     4楼一个可喜的前景是,未来,望闻问切可以和磁共振x光心电图水平仪经纬仪听......
  • 分段存储管理
    一、基本分段存储(逻辑)进程的地址空间按照程序自身的逻辑关系划分为若干个段(大小不同),每个段都有一个段名(在低级语言中,程序员使用段名来编程),每段从0开始编址......
  • MySQL 存储过程浅谈
    一、存储过程定义​存储过程(StoredProcedure):一组为了完成特定功能的SQL语句集,存储在数据库中,经过一次编译后不需要再次编译。二、存储过程特点1、可以完成复杂的判断和......
  • MySQL存储引擎
    1.MyISAM底层存储(非聚集索引方式)与InnoDB底层存储(聚集索引方式)1.1MyISAM底层存储(非聚集索引方式)Myisam创建表后生成的文件有三个:frm:创建表的语句MYD:表里面的数据文......