前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >基础知识 | 每日一练(121)

基础知识 | 每日一练(121)

作者头像
小林C语言
发布2019-09-23 13:06:22
2870
发布2019-09-23 13:06:22
举报

基础知识练习

读者:我想用 strcmp() 作为比较函数, 调用 qsort() 对一个字符串数组

排序, 但是不行。

小林:你说的 “字符串数组” 实际上是 “字符指针数组”。qsort 比较函数的参数是被排序对象的指针, 在这里, 也就是字符指针的指针。然而 strcmp() 只接受字符指针。因此, 不能直接使用 strcmp()。

写一个下边这样的间接比较函数:

/* 通过指针比较字符串 */

int pstrcmp(const void *p1, const void *p2)

{

return strcmp(*(char * const *)p1, *(char * const *)p2);

}

比较函数的参数表示为 “一般指针” const void *。然后, 它们被转换回本来表示的类型 (指向字符指针的指针), 再复引用, 生成可以传入 strcmp() 的 char*。

读者:怎样对一个链表排序?

小林:在建立链表时就一直保持链表的顺序要简单些)。插入排序和归并排序算法用在链表最合适了。如果希望用标准库函数, 可以分配一个暂时的指针数组, 填入链表中所有节点的地址, 再调用 qsort(), 最后依据排序后的数组重新建立链表。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-09-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 C语言入门到精通 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档