数据结构编程——求无向图连通子图.docVIP

数据结构编程——求无向图连通子图.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
#includestdio.h #includestdlib.h void DFS(int **a,int v,int *k,int n,int *visit){ int *S=(int *)malloc(50*sizeof(int)); int top=-1,j; (*k)++; visit[v]=1; ++top; S[top]=v; while(top!=-1){ v=S[top]; for(j=1;j=n;j++){ if(a[v][j]==1visit[j]==0){ (*k)++; visit[j]=1; S[++top]=j; break; } if(j==n)top--; } } } void xxxx(){ int n,m,i;//n个顶点,m条边 scanf(%d %d,n,m); int *visit=(int *)malloc((n+1)*sizeof(int)); int **a=(int **)malloc((n+1)*sizeof(int*)); int e,f; for(e=0;e=n;e++){ a[e]=(int *)malloc(sizeof(int)*(n+1)); } for(e=1;e=n;e++) for(f=1;f=n;f++) a[e][f]=0; for(e=1;e=n;e++) visit[e]=0; for(i=1;i=m;i++){ scanf(%d %d,e,f); a[e][f]=1; a[f][e]=1; } int k=0; int sum=0; int *b=(int *)malloc((n+1)*sizeof(int)); DFS(a,1,k,n,visit); sum++; b[0]=k; e=1; int v; for(v=1;v=n;v++){ k=0; if(visit[v]==0){ DFS(a,v,k,n,visit); sum++; b[e]=k; e++; } } printf(%d\n,sum); int t; for(i=0;isum-1;i++){ for(e=i+1,f=i;esum;e++) if(b[e]b[f])f=e; if(f!=e){ t=b[i];b[i]=b[f];b[f]=t; } } for(i=0;isum;i++){ printf(%d ,b[i]); } printf(\n); } int main(){ int xx,t; scanf(%d,t); for(xx=1;xx=t;xx++){ xxxx(); } system(pause); return 0; }

文档评论(0)

yan666888 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档