标题:按照输入的点,任意两个点的距离大小进行快速排序,哪里错了?
只看楼主
NeQhk
Rank: 2
等 级:论坛游民
威 望:1
帖 子:164
专家分:85
注 册:2014-7-19
结帖率:69.23%
已结贴  问题点数:20 回复次数:2 
按照输入的点,任意两个点的距离大小进行快速排序,哪里错了?
#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#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;
}
搜索更多相关主题的帖子: distance include double return 
2015-06-30 22:28
hjx1120
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:李掌柜
等 级:贵宾
威 望:41
帖 子:1314
专家分:6927
注 册:2008-1-3
得分:10 

a,数据类型不一致
b,函数原型:
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)));   
}

和这句代码
qsort(sum,i,sizeof(int),f)
可以这么写嘛
2015-06-30 22:41
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:10 
这……

10,50,k,你自己知道在干什么吗?
明明是是double*,却强制转化为 int*
还有 i++ 出现两次
变量更是瞎搞,瞻之在前,忽焉在后,这是吃药后太high了吧
2015-07-01 09:02



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-454913-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.505963 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved