WikiOI 1231 最优布线问题

这个问题让无数人崩溃,而且没有标程。我来贡献一个吧。。。。。。(从网上的标准kruskal+并查集代码改的)(我不会并查集)

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
struct self{int x,y;long long c;};
self s[1000001];
int a,b,m,n;
long long z=0;
int f[1000001];
int use[1000001];
bool firstuse[1000001]={0}; 

int find(int i)
{
return f[i]==i?i:f[i]=find(f[i]);
} 

int cmp(self a1,self a2)
{
return a1.c<a2.c;
}

long long kruskal1()
{
long long z=0;
int y=0;
for(int k=1;k<=n;k++)
{
int l=find(s[k].x);
int r=find(s[k].y);
if(l!=r)
{
firstuse[k]=1;
f[l]=r;
z+=s[k].c;
y++;
if(y==m-1)return z;

}
} 
return z;
}

long long kruskal()
{
long long z=0;
int y=0;
for(int k=1;k<=n;k++)
if(use[k])
{
int l=find(s[k].x);
int r=find(s[k].y);
if(l!=r)
{
f[l]=r;
z+=s[k].c;
y++;
if(y==m-1)return z;
}

} 
return z;
}

int main()
{
scanf("%d %d",&m,&n);
for(a=1;a<=n;a++)
{
f[a]=a;
scanf("%d %d %d",&s[a].x,&s[a].y,&s[a].c);
use[a]=1;
}
sort(s+1,s+n+1,cmp);

if(n<m-1)
{
printf("-1\n");
return 0;
}

z=kruskal();
printf("%lld\n",z);
return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
dp求解电路布线问题是一种常用的布线算法。该算法通过动态规划的思想,将整个布线问题划分为若干个子问题,并通过求解子问题的最优解来得到整体的最优解。 在电路布线问题中,我们需要将一些电子元件(比如电阻、电容等)连接在一起,形成一个电路板。但是由于电路板上空间有限,并且元件之间有一定的连接规则和限制条件,因此如何布置这些电子元件,使得电路性能达到最优,就成为了一个布线问题。 dp求解电路布线问题的关键是定义状态和状态转移方程。我们可以将电路板划分为若干个小格子,每个格子可以放置一个元件或者被留空。然后我们定义一个二维的dp数组,dp[i][j]表示前i个元件在前j个格子中的最优布线方案。状态转移方程可以通过考虑第i个元件放置在第j个格子和不放置在第j个格子两种情况来得到。 具体地,假设第i个元件需要和第k个元件连接(k < i),那么我们可以将第i个元件放置在第j个格子上(k < j < i),这样两个元件之间的连接就被实现了。而前k个元件的最优布线方案则可以通过dp[k][j]得到。然后我们遍历所有的k和j,找到使得总体性能最优的布线方案。 最后,通过计算得到的dp[n][m]即可得到整个电路布线问题最优解,其中n表示元件的数量,m表示格子的数量。 总之,dp求解电路布线问题是一种通过动态规划思想划分问题并解决子问题的方法,能够得到电路布线问题最优解。该算法在电子设计领域中应用广泛,可以有效提高布线的性能和效率。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值