开发者社区 问答 正文

按照输入的点,任意两个点的距离大小进行快速排序,怎么修改

#include
#include
#include
#define M 10
typedef struct {
int x;
int y;
int z;
}Point[M];
double distance(int x,int y,int z,int x1,int y1,int z1)
{
return ((double)sqrt((x-x1)*(x-x1)+(y-y1)*(y-y1)+(z-z1)*(z-z1)));

}
int f(const void c,const void *d)
{
return ((int*)c- (int)d);
}
int main()
{
Point point;
int k,n;
int x1,y1,z1;
int i=0;
int j;
int t=0;
double sum[50];
scanf("%d",&k);
for(i=0;i<k;i++)
{
scanf("%d%d%d",&x1,&y1,&z1);
point[i].x=x1;
point[i].y=y1;
point[i].z=z1;
i++;
}
for(j=0;j<i;j++)
{
for(k=j+1;k<i;k++)
{
sum[t]=distance(point[j].x,point[j].y,point[j].z,point[k].x,point[k].y,point[k].z);
}
}
qsort(sum,i,sizeof(int),f);
n=i;
for(i=0;i<n;i++)
printf("%lf ",sum[i]);
return 0;
} 

快速排序函数qsort
不可以对双精度的数进行排序吗?
写成
qsort(sum,i,sizeof(double),f)
不可以吗?

展开
收起
a123456678 2016-03-23 13:36:30 1846 分享 版权
1 条回答
写回答
取消 提交回答
  • 可以是可以,但是
    int f(const void c,const void d)
    {
    return ((int)c- (int)d);
    }

    这个你写错了
    应该转换成double *

    2019-07-17 19:10:47
    赞同 展开评论
问答地址: