hdu 1875

题目很简单,我却WA了几十次,找错误找了我一个小时;

蛋都碎了!

后来发现错误的地方竟然是memset;

用一个循环来替代它就A了;╮(╯▽╰)╭

今晚回去好好的看看memset!!!

发个代码纪念下,已经被我改的面目全非;

 #include<cstdio>
#include<cmath>
#define maxn 105
using namespace std;
double map[maxn][maxn];
int x[maxn],y[maxn];
bool v[maxn]; double prim(int n)
{
int i,j,flag;
v[]=;
double sum=0.0,lowcase[maxn];
for(i=; i<=n; i++)
{
lowcase[i]=map[][i];
v[i]=;
}
for(i=; i<n; i++)
{
flag=;
double min=20000.0;
for(j=; j<=n; j++)
if(!v[j]&&min>lowcase[j])
{
min=lowcase[j];
flag=j;
}
if(min>) return -20.0;
v[flag]=;
sum+=min;
for(j=; j<=n; j++)
if(!v[j]&&lowcase[j]>map[flag][j])
lowcase[j]=map[flag][j];
}
return sum;
} int main()
{
int n,m,t,i,flag,j;
double z;
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
for(i=; i<=n; i++)
for(j=; j<=n; j++)
map[i][j]=20000.0;
for(i=; i<=n; i++)
scanf("%d%d",&x[i],&y[i]);
for(i=; i<n; i++)
for(j=i+; j<=n; j++)
{
z=sqrt((x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]));
if(z>=10.00&&z<=1000.00)
map[i][j]=map[j][i]=z;
}
double sum=prim(n);
if(sum<)printf("oh!\n");
else printf("%.1lf\n",sum*);
}
return ;
}
上一篇:为什么使用Tailwind Css框架?


下一篇:Go 性能分析