| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 546 人关注过本帖
标题:拓扑排序
只看楼主 加入收藏
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
结帖率:79.37%
收藏
已结贴  问题点数:20 回复次数:7 
拓扑排序
我写了一个拓扑排序,但是好像有点问题,请各位高手帮我看看:
#include <stdio.h>
#include <stdlib.h>
int ans[100];
void topology(int map[100][100],int m,int n)
{
    int mark[100]={0};
    int i,j,k;
    for(i=0;i<n;i++)
    {
    for(j=0;j<n;j++)
    if(map[i][j]>0)
    mark[j]++;
    }
    for(i=0;i<n;i++)
    {
    j=0;
    while(mark[i]!=0) j++;
    ans[i]=j;
    mark[j]=-1;
    for(k=0;k<n;k++)
    if(map[k][j]>0)
    mark[k]--;
    }
}
int main()
{
    int map[100][100];
    int m,n,i;
    int start,end;
    scanf("%d %d",&m,&n);
    for(i=0;i<m;i++)
    {
    scanf("%d %d",&start,&end);
    map[start][end]=1;
    }
    topology(map,m,n);
    for(i=n-1;i>=0;i--)
    printf("%d ",ans[i]);
    system("pause");
    return 0;
}
搜索更多相关主题的帖子: include 
2011-03-23 20:42
waterstar
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:5
帖 子:984
专家分:2810
注 册:2010-2-12
收藏
得分:0 
有什么问题?

冰冻三尺,非一日之寒;士别三日,不足刮目相看!
2011-03-23 22:32
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
需要一个拓扑排序的测试数据

欢迎来到我的博客:http://blog..cn/noisunyuhong
2011-03-24 18:05
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
在网上找到了一个例题:http://58.51.82.174/JudgeOnline/showproblem?problem_id=1187
可是这个程序样例就过不去,请高手看看有什么问题?
#include <stdio.h>
#include <stdlib.h>
int ans[100];
void topology(int map[100][100],int n)
{
    int mark[100]={0};
    int i,j,k;
    for(i=0;i<n;i++)
    {
    for(j=0;j<n;j++)
    if(map[i][j]>0)
    mark[j]++;
    }
    mark[0]=1;
    for(i=0;i<n;i++)
    {
    j=0;
    while(mark[j]!=0) j++;
    ans[i]=j;
    mark[j]=-1;
    for(k=0;k<n;k++)
    if(map[j][k]>0)
    mark[k]--;
    }
}
int main()
{
    int map[100][100]={};
    int n,i;
    int start,end;
    scanf("%d",&n);
    for(i=0;i<n;i++)
    {
    scanf("%d %d",&start,&end);
    map[start][end]=1;
    }
    topology(map,n);
    for(i=0;i<n;i++)
    printf("%d ",ans[i]);
    system("pause");
    return 0;
}

欢迎来到我的博客:http://blog..cn/noisunyuhong
2011-03-25 20:17
草狼
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:2
帖 子:577
专家分:1040
注 册:2010-4-6
收藏
得分:0 
#include <stdio.h>
 #include <stdlib.h>
 int ans[100];
 void topology(int map[100][100],int m)
 {
     int mark[100]={0};
     int i,j,k;
     for(i=1;i<=m;i++)
     {
        for(j=1;j<=m;j++)
            if(map[i][j]==1)
                mark[j]++;
     }
     for(i=1;i<=m;i++)
     {
        j=1;
        while(mark[j]!=0 && j<=m) j++;
        ans[i]=j;
        mark[j]=-1;
        for(k=1;k<=m;k++)
            if(map[j][k]>0)
                mark[k]--;
     }
 }
 int main()
 {
     int map[100][100]={0};
     int m,n,i;
     int start,end;
     scanf("%d",&m);
     for(i=0;i<m;i++)
     {
         scanf("%d %d",&start,&end);
         map[start][end]=1;
     }
     topology(map,m);
     for(i=1;i<=m;i++)
         printf("%d ",ans[i]);
     system("pause");
     return 0;
 }
帮你改了下,那题目第一个案例能过了,但不知道总体对不对, 顺便说下,题目编号是从1开始的
2011-03-26 13:30
草狼
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:2
帖 子:577
专家分:1040
注 册:2010-4-6
收藏
得分:0 
#include <stdio.h>
 #include <stdlib.h>
 int ans[100];
 void topology(int map[100][100],int m)
 {
     int mark[100]={0};
     int i,j,k;
     for(i=1;i<=m;i++)
     {
        for(j=1;j<=m;j++)
            if(map[i][j]==1)
                mark[j]++;
     }
     for(i=1;i<=m;i++)
     {
        j=1;
        while(mark[j]!=0 && j<=m) j++;
        ans[i]=j;
        mark[j]=-1;
        for(k=1;k<=m;k++)
            if(map[j][k]>0)
                mark[k]--;
     }
 }
 int main()
 {
     int map[100][100]={0};
     int m,n,i;
     int start,end;
     scanf("%d",&m);
     for(i=0;i<m;i++)
     {
         scanf("%d %d",&start,&end);
         map[start][end]=1;
     }
     topology(map,m);
     for(i=1;i<=m;i++)
         printf("%d ",ans[i]);
     system("pause");
     return 0;
 }
帮你改了下,那题目第一个案例能过了,但不知道总体对不对, 顺便说下,题目编号是从1开始的
2011-03-26 13:30
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
这个我是知道的,但是每次测试下来输出都是1 2 3 4   请将我程序的问题说的具体一点好吗?
#include <stdio.h>
#include <stdlib.h>
int ans[100];
void topology(int map[100][100],int n)
{
    int mark[100]={0};
    int i,j,k;
    for(i=0;i<n;i++)
    {
    for(j=0;j<n;j++)
    if(map[i][j]>0)
    mark[j]++;
    }
    mark[0]=1;
    for(i=0;i<n;i++)
    {
    j=0;
    while(mark[j]!=0) j++;
    ans[i]=j;
    mark[j]=-1;
    for(k=0;k<n;k++)
    if(map[j][k]>0)
    mark[k]--;
    }
}
int main()
{
    int map[100][100]={};
    int n,i;
    int start,end;
    scanf("%d",&n);
    for(i=0;i<n;i++)
    {
    scanf("%d %d",&start,&end);
    map[start][end]=1;
    }
    topology(map,n);
    for(i=0;i<n;i++)
    printf("%d ",ans[i]);
    system("pause");
    return 0;
}

欢迎来到我的博客:http://blog..cn/noisunyuhong
2011-03-26 15:00
草狼
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:2
帖 子:577
专家分:1040
注 册:2010-4-6
收藏
得分:20 
应为你从0开始标记的所以会输出1 2 3 4;
你去void topology(int map[100][100],int n)
这函数里输出map值看看就知道了

顺便说下 topology(map,n);改成topology(map,n+1); 答案就跟案例一样咯
2011-03-26 16:46
快速回复:拓扑排序
数据加载中...
 
   



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

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