matlab画出最小生成树,图,最小生成树 MATLAB程序

function [b,u,w]=mintrees(a,k)%最小生成树 ,a 邻接矩阵,k 起点

if nargout==1

k=1;

end

[m,n]=size(a);

for i=1:m

for j=1:n

if a(i,j)==0

a(i,j)=inf;

end

end

end

b=zeros(n);

u(1)=k;

j=1;

v=zeros(1,n);

v(k)=1;

for o=1:n-1

sn=ones(3,n)*inf;

for xk=1:j

k=u(xk);

p=max(a(k,:));

for i=1:n

if v(i)<1&a(k,i)

p=a(k,i);

end

end

for i=1:n

if v(i)<1&a(k,i)==p

break;

end

end

sn([1 2 3],k)=[i,p,u(xk)];

end

[w(j),k]=min(sn(2,:));

j=j+1;

u(j)=sn(1,k);

b(sn(1,k),sn(3,k))=sn(2,k);

v(u(j))=1;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值