| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 562 人关注过本帖
标题:高手请进!!!编完后上传对比程序!!
只看楼主 加入收藏
q83390318
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2010-12-20
结帖率:25%
收藏
已结贴  问题点数:10 回复次数:3 
高手请进!!!编完后上传对比程序!!
对于给定的平面上的n个点和连接这n 个点的m条边,每条边连接两个点.
一笔画问题:找出给定的m条边的一条首尾相连的回路.使得从任何给定出发沿此回路点可以经过m条边的每条边恰好一次又回到出发点.
任务:对于给定的n个点和连接这n个点的m条边,用C语言编程计算一笔画回路.
数据输入:由文件input.txt给出的输入数据,第一行有两个正整数n和m,表示给定n个点和连接这n个点的m条边,点编号为1,2……n。接下来的m行中,每行有2个正整数u,v,表示连接点u和v的一条边。
结果输出:
将编程计算出的一笔画回路输出到文件output.txt中,如果不存在一笔画回路则输出-1
搜索更多相关主题的帖子: C语言 出发点 连接点 正整数 
2010-12-29 18:58
诸葛修勤
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:11
帖 子:549
专家分:1955
注 册:2010-10-28
收藏
得分:10 
这个顶上去  大家 做做
2010-12-30 15:47
诸葛修勤
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:11
帖 子:549
专家分:1955
注 册:2010-10-28
收藏
得分:0 
ding shang qu
2010-12-31 09:19
诸葛修勤
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:11
帖 子:549
专家分:1955
注 册:2010-10-28
收藏
得分:0 
程序代码:
//求最长简单回路
#include <stdio.h>
#include <stdlib.h>

FILE *fin, *fout;//定义输入输出文件指针为全局变量

char buffer;//定义缓冲区
int data;//存放当前获取的数字

/*****************图的存储结构 邻接表***************/
struct Arc
{
    int v;//向量表中的下标值
    struct Arc *next;
};

struct Graph
{
    struct Arc *vex_array;//顶点向量表
    int vex_num;//顶点数
    int arc_num;//边条数
};
/**************************************************/

/**************** 全局函数 ************************/
void get_char();
void get_sym();
void initial_graph(struct Graph **G);
int search_index(struct Graph *G, int elem);
void traverse(struct Graph *G, int *symbol, int index, int *count);
void way(struct Graph *G);
/**************************************************/
int main()
{
    if( (fin=fopen("D:\\input.txt", "r")) == NULL )
    {
        printf("读取文件失败!\n");
        exit(-1);
    }
    if( (fout=fopen("D:\\output.txt", "w")) == NULL )
    {
        printf("写文件失败!\n");
        exit(-1);
    }
   
    struct Graph *G=NULL;//定义指向图的指针变量
    initial_graph(&G);
    way(G);

    return 0;
}

void way(struct Graph *G)
{
    int *symbol = (int *) malloc ((G->vex_num+1)*sizeof(int));//定义标志位 判断是否访问过
    for(int i=0; i<=G->vex_num; ++i )
    {
        symbol[i] = 0;//全部初始化为 没有访问过
    }
    symbol[1] = 1;
    int count = 1;//统计有多少点在一条线上
    for(struct Arc *p=G->vex_array[1].next; p!=0; p=p->next)
    {
        if( !symbol[p->v] )
        {
            symbol[p->v] = ++count;
            if( count == G->vex_num )
            {
                break;
            }
            traverse(G, symbol, p->v, &count);
            if( count == G->vex_num )
            {
                break;
            }
            symbol[p->v] = 0;
            --count;
        }
    }
    //判断最后一个点是否和开始一个点相连接
    --count;
    p = G->vex_array[1].next;
    while(p)
    {
        if( p->v == symbol[G->vex_num] )
        {
            ++count;
        }
        p = p->next;
    }

    if( count == G->vex_num )
    {
        printf("\t找到\n");   
        for(i=1; i<=G->vex_num; ++i )
        {
            printf("%d ",symbol[i]);
        }
    }
}
void traverse(struct Graph *G, int *symbol, int index, int *count)
{
    for(struct Arc *p=G->vex_array[index].next; p!=0; p=p->next)
    {
        if( !symbol[p->v] )
        {
            symbol[p->v] = ++(*count);
            if( *count == G->vex_num )
            {
                return;
            }
            traverse(G, symbol, p->v, count);
            if( *count == G->vex_num )
            {
                return;
            }
            symbol[p->v] = 0;
            --(*count);
        }
    }
}
void get_char()
{
    if( !feof(fin) )
    {
        fscanf(fin,"%c", &buffer);
        putchar(buffer);
    }
    return;
}
/*获取一个有用的数字*/
void get_sym()
{
    data = 0;//重新置零
    get_char();//获取一个符号
    while( buffer==10 || buffer==9 || buffer==' ' )
    {//过滤掉文件中的换行符 和 空格
        get_char();
    }
    while(buffer!=10 && buffer!=9 && buffer!=' ')
    {
        data = data*10 + buffer - '0';
        get_char();
       
    }
}

/*初始化图*/
void initial_graph(struct Graph **G)
{
    int i;
    *G = (struct Graph*) malloc (sizeof(struct Graph));
    if( NULL==(*G) )
    {
        printf("\t内存不足!\n");
        exit(-1);
    }
    get_sym();
    (*G)->vex_num = data;//初始化顶点数量
    get_sym();
    (*G)->arc_num = data;//初始化弧的数量

    //分配比顶点个数多一个单位的长度空间  使用的时候零号单元不使用
    (*G)->vex_array = (struct Arc*) malloc (((*G)->vex_num+1)*sizeof(struct Arc*));
    for( i=0; i<=(*G)->arc_num; ++i )
    {
        (*G)->vex_array[i].v = i;
        (*G)->vex_array[i].next = NULL;
    }

    int v1_site, v2_site, v1, v2;
    for( i=1; i<=(*G)->arc_num; ++i)
    {
        get_sym();
        v1 = data;//弧尾的值
        v1_site = search_index(*G, v1);//弧尾在顶点向量表中的下标值
        get_sym();
        v2 = data;//弧头的值
        v2_site = search_index(*G, v2);//弧头在顶点向量表中的下标值
        //判断弧是否合法
        if( !v1_site || !v2_site )
        {
            printf("\t顶点信息录取有误!\n");
            exit(-1);
        }

        struct Arc *p=NULL;
        p = (struct Arc*) malloc (sizeof(struct Arc));
        p->v = v2;
        p->next = (*G)->vex_array[v1].next;
        (*G)->vex_array[v1].next = p;

        p = (struct Arc*) malloc (sizeof(struct Arc));
        p->v = v1;
        p->next = (*G)->vex_array[v2].next;
        (*G)->vex_array[v2].next = p;
    }
    return;
}
/*查找顶点在顶点向量表中的下标值*/
int search_index(struct Graph *G, int elem)
{
    int i=0;
    G->vex_array[0].v = elem;
    for(i=G->vex_num; elem != G->vex_array[i].v; --i );//找到则停止

    return i;
}
图片附件: 游客没有浏览图片的权限,请 登录注册
2010-12-31 20:42
快速回复:高手请进!!!编完后上传对比程序!!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.039609 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved