LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 852|回复: 4

请教qsort

[复制链接]
发表于 2003-12-17 18:22:20 | 显示全部楼层 |阅读模式
先建下面构造体
typedef struct _xy {
  int    xx;
  int    yy;
}XY;

XY **xy;

xy里追加10组数据

qsort(xy, 10, sizeof(xy[0]), sortXY);

int sortXY(const void *aa, const void *bb)
{
  const XY **a = (const XY **)aa;
  const XY **b = (const XY **)bb;

  if( *a->xx < *b->xx ) return -1;
  else if( *a->xx == *b->xx ) return 0;
  return 1
}

上面的用法对不对?
purify编译执行出现下面错误,怎么解决,请指教
Uninitialized memory read (4 times)
=> qsort(xy, 10, sizeof(xy[0]), sortXY);
发表于 2003-12-18 01:57:18 | 显示全部楼层
xy是不是没有分配空间
发表于 2005-5-9 21:57:18 | 显示全部楼层
Post by x11
xy是不是没有分配空间

qsort最后那个比较函数该怎么写?
可以不写吗?
回复 支持 反对

使用道具 举报

发表于 2005-5-9 22:05:47 | 显示全部楼层
Post by mzt
先建下面构造体
typedef struct _xy {
  int    xx;
  int    yy;
}XY;

XY **xy;

xy里追加10组数据

qsort(xy, 10, sizeof(xy[0]), sortXY);

int sortXY(const void *aa, const void *bb)
{
  const XY **a = (const XY **)aa;
  const XY **b = (const XY **)bb;

  if( *a->xx < *b->xx ) return -1;
  else if( *a->xx == *b->xx ) return 0;
  return 1
}

上面的用法对不对?
purify编译执行出现下面错误,怎么解决,请指教
Uninitialized memory read (4 times)
=> qsort(xy, 10, sizeof(xy[0]), sortXY);


当然不对,如果你排的是指针,应该是:
qsort(xy, 10, sizeof (void *), sortXY);
比较函数也不完全对,应该是:
int sortXY(const void *aa, const void *bb)
{
  XY *const *a = (XY * const*)aa;
  XY *const *b = (XY * const*)bb;

  if( *a->xx < *b->xx ) return -1;
  else if( *a->xx == *b->xx ) return 0;
  return 1
}
或:
int sortXY(const void *aa, const void *bb)
{
  XY *a = *(XY * const*)aa;
  XY *b = *(XY * const*)bb;

  if(a->xx < b->xx ) return -1;
  else if(a->xx == b->xx ) return 0;
  return 1
}
我倾向于第二种写法。
回复 支持 反对

使用道具 举报

发表于 2005-5-9 22:08:51 | 显示全部楼层
说错,sizeof(xy[0])也可以。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表