C语言根据汉字拼音首字母排序

这是一篇关于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
评论 17
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值