24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 616  |  回复: 8

liujianxi

金虫 (正式写手)

[求助] 邻接表的导入

txt 文件的内容是:
1 2
1 3
1 4
2 3
2 5
//----------------------
表 顶点1和顶点2有边相连。。。
现在需要建立程序把文件导入到cpp中,
用 vector Edge[M];(//define M 5000, 邻接表表示)来记录。
请高手指点,写出程序,非常感谢!
回复此楼

» 猜你喜欢

Wemustknow,wewillknow.
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lurencyj

木虫 (著名写手)

看不懂。

[ 发自手机版 http://muchong.com/3g ]
很女子很弓虽大
2楼2012-04-10 22:30:38
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liujianxi

金虫 (正式写手)

文本的邻接表是:
Edge[1]={2,3,4};
Edge[2]={1,3,5};
Edge[3]={1,2};
Edge[4]={1};
Edge[5]={2};
Wemustknow,wewillknow.
3楼2012-04-10 23:17:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liujianxi

金虫 (正式写手)

文本表达的是一个图的顶点及其边的信息
Wemustknow,wewillknow.
4楼2012-04-10 23:19:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Nicholas3888

金虫 (小有名气)

liujianxi: 回帖置顶 2012-04-13 09:05:56
引用回帖:
4楼: Originally posted by liujianxi at 2012-04-10 23:19:44:
文本表达的是一个图的顶点及其边的信息

你意思是文本里每一行是一条边的起点和终点,然后要求将文本中这些内容以邻接表形式导入程序中?
高唱红歌治脑瘫
5楼2012-04-11 22:07:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liujianxi

金虫 (正式写手)

引用回帖:
5楼: Originally posted by Nicholas3888 at 2012-04-11 22:07:58:
你意思是文本里每一行是一条边的起点和终点,然后要求将文本中这些内容以邻接表形式导入程序中?

6楼2012-04-13 09:04:32
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Nicholas3888

金虫 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
liujianxi: 金币+30, ★★★★★最佳答案, 很好很强大 2012-04-13 17:41:24
xzhdty: 金币+2, 欢迎常来程序语言看看 2012-04-13 18:03:24
引用回帖:
6楼: Originally posted by liujianxi at 2012-04-13 09:04:32:

#include
#include

/*********
* 假设dat.txt文件保存有你所谓的边节点信息
*   1 2
*   1 3
*   1 4
*   2 3
*   2 5
*   3 1
*   4 1
*   5 2
*********/

#define NODE_NUM    5

typedef int ELEM;

typedef struct edge_node{
    int adjvex;
    struct edge_node *pNext;
    ELEM dat;
}edge_node_t;

typedef struct node{
    ELEM dat;
    struct edge_node *pFirstArc;
}node_t;

node_t n[NODE_NUM];

void node_init(node_t *pList, int nodeNum){
    int i;

    for(i=0; i         pList->dat=i;
        pList->pFirstArc=NULL;
        pList++;
    }
}

void list_traverse(node_t *pList, int nodeNum){
    int i;
    edge_node_t *pTemp=NULL;

    for(i=0; i         printf("Edge[%d]={", i+1);
        pTemp=pList->pFirstArc;
        while(pTemp){
            printf("%d ", pTemp->adjvex);
            pTemp=pTemp->pNext;
        }
        printf("}\n";
        pList++;
    }
}

int main(void){
    FILE *fp;
    char temp[5], enter[2];
    int index;
    edge_node_t *newEdge, *pTemp;

    node_init(n, NODE_NUM);
    fp=fopen("dat.txt", "r";
    if(fp == NULL){
        printf("open file failed.\n";
        return 0;
    }else{
        while(fscanf(fp, "%[^\n]s", temp) != EOF){
            //printf("read str:%s\n", temp);
            newEdge=(edge_node_t *)malloc(sizeof(edge_node_t));
            newEdge->adjvex=temp[2]-'0';
            index=temp[0]-'0'-1;
            if(index < 0){
                printf("error\n";
            }
            pTemp=n[index].pFirstArc;
            n[index].pFirstArc=newEdge;
            newEdge->pNext=pTemp;
            fscanf(fp, "%c", enter);    //next line
        }
    }
    list_traverse(n, NODE_NUM);

    return 0;
}

程序是gcc编译的,运行结果如下

运行结果

高唱红歌治脑瘫
7楼2012-04-13 15:52:14
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Nicholas3888

金虫 (小有名气)

貌似代码中一个反括号加上一个冒号是一个表情的快捷键,被替换了,哈哈……

» 本帖已获得的红花(最新10朵)

高唱红歌治脑瘫
8楼2012-04-13 15:54:59
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liujianxi

金虫 (正式写手)

送鲜花一朵
引用回帖:
8楼: Originally posted by Nicholas3888 at 2012-04-13 15:54:59:
貌似代码中一个反括号加上一个冒号是一个表情的快捷键,被替换了,哈哈……

很好很强大,
非常感谢!
Wemustknow,wewillknow.
9楼2012-04-13 17:39:55
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 liujianxi 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 285求调剂 +3 AZMK 2026-04-02 4/200 2026-04-02 23:58 by wwytracy
[考研] 交通运输考试264分求工科调剂 +4 jike777 2026-04-02 4/200 2026-04-02 21:53 by zllcz
[考研] 330分求调剂 +15 qzenlc 2026-03-29 15/750 2026-04-02 21:41 by 百灵童888
[考研] 一志愿上海海洋大学083200食品学硕,求调剂,接受其他专业 +6 what张 2026-04-01 7/350 2026-04-02 16:48 by zzsw+
[考研] 321求调剂 一志愿 浙江工业大学生物医药 +5 嘿嘿HC 2026-04-01 6/300 2026-04-02 15:23 by sophie2180
[考研] 初试301,代码085701环境工程,本硕一致,四六级已过,有二区一作,共发表5篇论文 +6 axibli 2026-04-01 6/300 2026-04-02 13:42 by Ecowxq666!
[考研] 材料化工340求调剂 +5 jhx777 2026-03-30 5/250 2026-04-02 12:45 by smileboy2006
[考研] 085600,材料与化工321分,求调剂 +13 大馋小子 2026-03-27 13/650 2026-04-02 10:48 by sanrepian
[考研] 材料科学与工程调剂 +18 深V宿舍吧 2026-03-30 19/950 2026-04-02 10:28 by sanrepian
[考研] 07生物学求调剂 一志愿同济大学359分 +3 LAMC. 2026-03-30 3/150 2026-04-02 10:26 by 18828373951
[考研] 考研调剂 +12 Amber00 2026-03-31 12/600 2026-04-02 09:04 by sanrepian
[考研] 085410 一志愿211 22408分数359求调剂 +3 123456789qw 2026-03-31 4/200 2026-04-02 00:06 by 义文wang
[考研] 一志愿南昌大学324求调剂 +7 hanamiko 2026-03-30 7/350 2026-04-01 13:22 by JourneyLucky
[考研] 318求调剂 +8 七忆77 2026-04-01 8/400 2026-04-01 10:37 by Jaylen.
[考研] 0855机械初试280求调剂 +3 kazenotori 2026-03-31 3/150 2026-04-01 10:08 by JourneyLucky
[考研] 289求调剂 +7 BrightLL 2026-03-29 7/350 2026-03-31 22:05 by 544594351
[考研] 本科211安全工程,初试290分,求调剂 +3 2719846834 2026-03-28 3/150 2026-03-31 13:52 by 热情沙漠
[考研] 一志愿中海洋320化学工程与技术学硕求调剂 +8 披星河 2026-03-30 8/400 2026-03-31 08:53 by lbsjt
[考研] 332求调剂 +6 @MZB382400 2026-03-28 6/300 2026-03-30 16:57 by 无际的草原
[考研] 279求调剂 +4 蝶舞轻绕 2026-03-29 4/200 2026-03-29 09:45 by laoshidan
信息提示
请填处理意见