//1:对二维char数组排序
//解决办法有:https://blog.csdn.net/hellotomhaha/article/details/60872218?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-4.nonecase&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-4.nonecase
//1.用qsort
//void qsort(void *base, int nelem, int width, int (*fcmp)(const void *,const void *));//函数指针的作用
//功 能 : 使用快速排序例程进行排序
//https://www.cnblogs.com/AndyJee/p/4676146.html
//参 数:
//
//1 待排序数组首地址
//
//2 数组中待排序元素数量
//
//3 各元素的占用空间大小
//
//4 指向函数的指针,用于确定排序的顺序
int cmp(const void* e1, const void* e2)
{
return strcmp((char *)e1, (char *)e2);
}
qsort(tel, n, 9, cmp);
//2.改用string
//为什么printf不能输出str:
/*1.printf函数输出字符串是针对char *的,即printf只能输出c语言的内置数据类型,而string不是c语言的内置数据类型。
2.string类型的对象不止包含字符串,还包含了许多用于操作的函数,所以&str并非字符串的首地址。
3.如需输出string对象中的字符串,可以使用string的成员函数c_str(),该函数返回字符串的首字符的地址;或者用cin和cout进行字符串的输出string不是c语言的内置函数
*/
//3.把二维数组 改成struct的一维数组
//4:用vector<char*>也可以
//int cmp(const void* e1, const void* e2)
//{
// return strcmp((char *)e1, (char *)e2);
//}
对二维数组的排序
最新推荐文章于 2022-06-04 22:08:27 发布