这是一篇关于C语言根据姓名拼音首字母排序的文章。
我想到写这篇文章,主要是因为我在学校期末课设做通讯录管理,我想做一个姓名拼音首字母排序,但是在网上找了好多都是些奇奇怪怪的方法,有用glib库里的,但是现在版本的Dev-C++并没有这个库。还有用一些神奇的函数取文字拼音首字母再排序的,这个方法我是没看懂也不确定是否是C语言的(因为那篇文章没有标明所用语言,里面还用了好多我没见过的指令)
后来,我在重新翻教材看案例时看到了strcmp,虽然教材上的案例是对英文单词进行排序,但是我也发现,当我们储存字符串时,储存名字时其实是把拼音字母存进去的,那我是否也可以用strcmp实现汉字的排序呢?
这是教材上的排序函数部分:
void sort(char *strings[],int n)
{
char *temp;
int i,j;
for(i=0;i<n-i;i++)
{
for(j=i+1;j<n;j++)
{
if(strcmp(strings[i],strings[j])>0)
{
temp=strings[i];
strings[i]=strings[j];
strings[j]=temp;
}
}
}
}
是不是发现这其实就是冒泡排序,没错,这就是用冒泡排序来排序字符,用strcmp来实现字符的先后顺序比较。然后再以跳板temp来实现两个字符串的交换。
但是我在运用到我的通讯录管理系统的时候却提示"error:assignment to expression with array type."这是赋值失败的提示,可能是类型不同或者其他什么原因导致的。在我多次尝试修改类型无果后,我决定用strcpy来交换字符串内容。
以下是优化后的教材代码:
void sort(char *strings[],int n)
{
char *temp;
int i,j;
for(i=0;i<n-i;i++)
{
for(j=i+1;j<n;j++)
{
if(strcmp(strings[i],strings[j])>0)
{
strcpy(temp,strings[i]);
strcpy(strings[i],strings[j]);
strcpy(strings[j],temp);
}
}
}
}
这样就解决了赋值失败的问题。
其实都是旧方法,都是学过的知识,但是重点就在于如何运用。
接下来奉上我的通讯录管理系统的完整代码:
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct//定义结构体
{
char name[20];
char phone[50];
char address[20];
int post;
char mail[50];
}data;
int n=0;//定义储存数量
data a[1000];//定义结构体数组
FILE*fp;//定义文件指针
void load(data*p)//读取文件函数
{
int i;
fp=fopen("link.dat","rb");//打开文件,初始化文件指针为读取/更新
if(fp==NULL)//判空
return;
fread(&n,sizeof(int),1,fp);//读取数量
for(i=0;i<n;i++)//读取文件中的内容
fread(&p[i],sizeof(data),1,fp);
return;
}
void save (data*p)//写入/更新文件函数
{
int i;
fp=fopen("link.dat","wb");//打开文件,初始化文件指针为写入/更新
if(fp==NULL)//判空操作
{
printf("文件打开失败\n");
exit(0);
}
else
fwrite(&n,sizeof(int),1,fp);//输入数量
for(i=0;i<n;i++)//输入进文件中
fwrite(&p[i],sizeof(data),1,fp);
printf("\n");
fclose(fp);//关闭文件
return;
}
void add(data*p)//添加联系人
{
if(n==1000)//判断容量是否超过
printf("容量已满\n");
else
{
printf("请输入姓名:\n");
scanf("%s",p[n].name);
printf("请输入电话号码:\n");
scanf("%s",p[n].phone);
printf("请输入住址:\n");
scanf("%s",p[n].address);
printf("请输入邮编:\n");
scanf("%d",&p[n].post);
printf("请输入电子邮箱:\n");
scanf("%s",p[n].mail);
printf("添加成功\n");
n++;
}
return;
}
void find(data*p)//查询联系人
{
int i,x;
char b[20];//定义存储输入的名字数组
char c[20];//定义存储输入的电话数组
printf("请选择查询方式:\n");
printf