c语言用数组做通讯录 怎样将联系人的姓名首字母排序 并且输出 求大侠
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c语言用数组做通讯录 怎样将联系人的姓名首字母排序 并且输出 求大侠相关的知识,希望对你有一定的参考价值。
参考技术A 排序部分for(j=0;j<n-1;j++)
for(i=0;i<n-1-j;i++)
if((strcmp(wds[i],wds[i+1]))>0)//每个数组元素都是字符串
t=wds[i];
wds[i]=wds[i+1];
wds[i+1]=t;
//冒泡排序
输出部分
for(k=0;i<n;k++)
puts(wds[i]);
本回答被提问者采纳 参考技术B 学过排序吗?先用strcmp()比较大小,排序,然后顺序输出追问
就是能排序 但是在整个程序里排序之后不能输出 ...
参考技术C 一楼正解 就是strcmp 参考技术D 把你的代码发出来才能找毛病啊C语言实现通讯录(文件操作)
通讯录实现功能
实现一个通讯录;
通讯录可以用来存储1000个人的信息,每个人的信息包括:姓名、性别、年龄、电话、住址
提供方法:
1.添加联系人信息
2.删除指定联系人信息
3.查找指定联系人信息
4.修改指定联系人信息
5.显示所有联系人信息
6.清空所有联系人
7.以名字排序所有联系人
8. 添加一个函数,在退出通讯录的时候把信息到保存到文件中
9. 添加一个函数,在通讯录打开的时候,可以把文件中的信息加载到通讯录中
过程分析
数据结构
存储一个学生的信息,需要用到结构体。
现在需要存储任意人数的信息,由于人数不确定,所以采用柔性数组来实现空间的动态分配。
步骤
1.创建需要用到的数据结构
2.编写初始化空间的函数
3.依次编写每个功能模块
4.汇总,在主函数中调用
代码展示
此次编程采用多文件的方式,尽可能使代码简化。读者耐心阅读肯定可以看懂。
不再废话,直接上代码
contact.h
#include <stdio.h>
#include <windows.h>
#include <assert.h>
#include <stdlib.h>
#pragma warning(disable:4996)
#define DFL_NUM 2
#define INC_NUM 2
#define MY_FILE "my_file.bin"
typedef struct person{
char name[32];
char sex[4];
int age;
char telphone[16];
char address[64];
}person_t;
typedef struct contact{
int cap;//当前容量总数
int size;//当前的实际人数
person_t persons[0];//柔性数组
}contact_t;
extern void InitContact(contact_t **ctp);
extern void DestroyContact(contact_t **ctp);
extern void AddPerson(contact_t **ctp);
extern void PrintContact(contact_t *ct);
extern void SearchPerson(contact_t *ct);
extern void DeletePerson(contact_t *ct);
extern void ModPerson(contact_t *ct);
extern void ClearContact(contact_t *ct);
extern void SortContact(contact_t *ct);
extern void My_File(contact_t *ct);
contact.c
#include "contact.h"
void InitContact(contact_t **ctp)
{
FILE *fp = fopen(MY_FILE,"rb");
if (NULL == fp)
{
//默认初始化
*ctp = (contact_t*)malloc(sizeof(contact_t)+sizeof(person_t)*DFL_NUM);
if (NULL == *ctp)
{
perror("malloc");
exit(1);
}
(*ctp)->cap = DFL_NUM;
(*ctp)->size = 0;
printf("Default contact init..... done\\n");
}
else
{
contact_t t;
fread(&t,sizeof(contact_t),1,fp);
*ctp = (contact_t *)malloc(sizeof(contact_t)+sizeof(person_t)*t.cap);
if (NULL == *ctp)
{
perror("malloc");
exit(2);
}
fread((*ctp)->persons, sizeof(person_t), t.size, fp);
(*ctp)->cap = t.cap;
(*ctp)->size = t.size;
fclose(fp);
printf("File contact init ... done\\n");
}
}
void DestroyContact(contact_t **ctp)
{
free(*ctp);
*ctp = NULL;
printf("Destroy ccontact ....done\\n");
}
static int Inc(contact_t **ctp)//返回值 1扩容成功 0失败
{
contact_t *temp = NULL;
temp = (contact_t *)realloc(*ctp, sizeof(contact_t)+sizeof(person_t)*((*ctp)->cap + INC_NUM));
if (NULL == temp)
{
perror("realloc");
return 0;
}
temp->cap = (*ctp)->cap + INC_NUM;
temp->size = (*ctp)->size;
*ctp = temp;
printf("扩容成功!cap:%d size:%d\\n",temp->cap,temp->size);
return 1;
}
static int isFull(contact_t *ct)// 返回值 1满了 0没满
{
return (ct->cap == ct->size);
}
static void PrintContactHelper(person_t *p)
{
printf("|%-5s|%-5s|%-2d|%10s|%10s|\\n",p->name,p->sex,p->age,p->telphone,p->address);
}
static int FindPerson(const contact_t *ct,const char *name)
{
const person_t *p = ct->persons;
for (int i = 0; i < ct->size; i++)
{
if (strcmp(name, (p + i)->name) == 0)
{
return i;
}
}
return -1;
}
static int CompareName(const void *xp,const void *yp)// 0 相等 1 前者大 2后者大
{
const person_t *p = (const person_t *)xp;
const person_t *q = (const person_t *)yp;
return strcmp(p->name, q->name);
}
void AddPerson(contact_t **ctp)
{
//是否可以添加??--->1.没满直接添加 2.满了,扩容成功后添加
if (!isFull(*ctp) || Inc(ctp))
{
contact_t *ct = *ctp;
person_t *p = ct->persons + ct->size;
printf("请输入联系人姓名#");
scanf("%s",p->name);
int index = FindPerson(ct, p->name);
if (index != -1)
{
printf("此联系人已经存在!\\n");
return;
}
printf("请输入联系人性别#");
scanf("%s",p->sex);
printf("请输入联系人年龄#");
scanf("%d",&(p->age));
printf("请输入联系人电话#");
scanf("%s",p->telphone);
printf("请输入联系人地址#");
scanf("%s",p->address);
ct->size++;
}
}
void PrintContact(contact_t *ct)
{
for (int i = 0; i < ct->size; i++)
{
PrintContactHelper(ct->persons+i);
}
}
void DeletePerson(contact_t *ct)
{
//1.判断是否可以找到这个人
char name[64];
printf("请输入要删除人的姓名#");
scanf("%s", name);
int index = FindPerson(ct, name);
if (index != -1)//找到此人,开始删除
{
memmove(ct->persons+index,ct->persons+ct->size-1,sizeof(person_t));
ct->size--;
printf("[%s] 删除成功!\\n",name);
}
else//此人不存在,无法删除
{
printf("[%s]不存在,无法删除!", name);
return;
}
}
void SearchPerson(contact_t *ct)
{
char name[64];
printf("请输入要查找人的姓名#");
scanf("%s",name);
int index = FindPerson(ct,name);
if (index != -1)
{
PrintContactHelper(ct->persons + index);
}
else
{
printf("[%s] 不存在!\\n",name);
}
}
void ModPerson(contact_t *ct)
{
char name[64];
printf("请输入要查找人的姓名#");
scanf("%s", name);
int index = FindPerson(ct, name);
if (index != -1)//存在,修改信息
{
person_t *p = ct->persons + index;
printf("请输入联系人姓名#");
scanf("%s", p->name);
printf("请输入联系人性别#");
scanf("%s", p->sex);
printf("请输入联系人年龄#");
scanf("%d", &(p->age));
printf("请输入联系人电话#");
scanf("%s", p->telphone);
printf("请输入联系人地址#");
scanf("%s", p->address);
}
else
{
printf("[%s] 不存在,无法修改!\\n", name);
}
}
void ClearContact(contact_t *ct)
{
ct->size = 0;
printf("Clear contact...done\\n");
}
void SortContact(contact_t *ct)
{
qsort(ct->persons, ct->size, sizeof(person_t), CompareName);
}
void My_File(contact_t *ct)
{
FILE *fp = fopen(MY_FILE,"wb");
if (NULL == fp)
{
perror("fopen");
return;
}
fwrite(ct,sizeof(contact_t),1,fp);
fwrite(ct->persons, sizeof(person_t), ct->size, fp);
fclose(fp);
}
main.c
#include "contact.h"
void menu()
{
printf("#################################\\n");
printf("## 1.Add 2.Delete ##\\n");
printf("## 3.Search 4.Modify ##\\n");
printf("## 5.Show 6.Clear ##\\n");
printf("## 7.Sort 0.Exit ##\\n");
printf("#################################\\n");
}
int main()
{
contact_t *ct = NULL;
InitContact(&ct);
int quit = 0;
int select = 0;
while (!quit)
{
menu();
printf("Please enter your choose#");
scanf("%d", &select);
switch (select)
{
case 1:
AddPerson(&ct);
break;
case 2:
DeletePerson(ct);
break;
case 3:
SearchPerson(ct);
break;
case 4:
ModPerson(ct);
break;
case 5:
PrintContact(ct);
break;
case 6:
ClearContact(ct);
break;
case 7:
SortContact(ct);
break;
case 0:
quit = 1;
My_File(ct);
break;
default:
printf("输入有误,请重新输入!\\n");
break;
}
}
DestroyContact(&ct);
system("pause");
return 0;
}
读者可以copy到自己的环境下测试~~
以上是关于c语言用数组做通讯录 怎样将联系人的姓名首字母排序 并且输出 求大侠的主要内容,如果未能解决你的问题,请参考以下文章