关于C语言中文排序问题
本帖最后由 FengYue20 于 2022-6-15 23:11 编辑今天做通讯录系统的时候突然有一个大胆的想法,就是输出的时候根据姓名的首字母进行排序,然后用strcmp比对大小来获取排序方法,结果发现输出根本不是我想要的,代码如下:
int main(void)
{
char *strings[]={
"王华",
"张丽",
"李强"
};
char *temp;
int i,j;
for(i=0;i<3-i;i++)
{
for(j=i+1;j<3;j++)
{
if(strcmp(strings,strings)>0)
{
temp=strings;
strings=strings;
strings=temp;
}
}
}
for(i=0;i<3;i++)
{
printf("%s\t",strings);
}
putchar('\n');
return 0;
}
输出结果为:张丽 李强 王华
然后又想根据GB2312的编码进行排序,下面是网络上找的代码,gcc编译得到的结果和网络上不相同
int main(void)
{
char a;
strcpy(a,"啊");
printf("%X %X\n",(unsigned char)a,(unsigned char)a);//程序运⾏结果是a=B0 a=A1
return 0;
}
但我的gcc编译后为E5 95
想请问各位大佬关于C语言根据中文进行排序的问题该如何解决!!!!!!{:9_231:} $ cat main.c
#include <stdio.h>
#include <string.h>
#include <locale.h>
int main(void) {
setlocale(LC_ALL, "zh_CN.UTF-8");
const char *strings[] = {
"王华",
"张丽",
"李强"
};
for(size_t i = 0; i < 3; ++i) {
for(size_t j = i + 1; j < 3; ++j) {
//if(strcmp(strings, strings) > 0) {
if(strcoll(strings, strings) > 0) {
const char *temp = strings;
strings = strings;
strings = temp;
}
}
}
for(size_t i = 0; i < 3; ++i)
printf("%s\n", strings);
return 0;
}
$ gcc-debug -o main main.c
$ ./main
李强
王华
张丽
$ 网上查strcmp函数是对字符的ASCII值进行比较,你要的是对姓名的首字母(拼音)排序。函数用错了吧。我不知道C里面有没有汉字对应拼音的库或者函数。但是可以肯定你用的函数错了。 顶级太阳 发表于 2022-6-16 08:00
网上查strcmp函数是对字符的ASCII值进行比较,你要的是对姓名的首字母(拼音)排序。函数用错了吧。我不知 ...
网上说GB2312-80的一级汉字是使用拼音进行排序,可以用strcmp进行排序,然后我才用的,该链接描述的https://blog.csdn.net/Orlando321/article/details/78313985?spm=1001.2101.3001.6661.1&utm_medium=distribute.pc_relevant_t0.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-1-78313985-blog-121724603.pc_relevant_downloadblacklistv1&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-1-78313985-blog-121724603.pc_relevant_downloadblacklistv1&utm_relevant_index=1
我把它的排序改为冒泡排序法,该链接源代码使用gcc运行后和我代码得到的结果是一模一样 人造人 发表于 2022-6-15 23:37
大佬牛逼(撕心裂肺的叫喊)~~~
页:
[1]