C语言实现一个通讯录

 更新时间:2018年02月15日 09:28:45   作者:persistence_s  
这篇文章主要为大家详细介绍了用C语言实现一个通讯录,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

实现一个通讯录,通讯录可以用来存储1000个人的信息,每个人的信息包括:

姓名、性别、年龄、电话、住址

提供方法:

1. 添加联系人信息
2. 删除指定联系人信息
3. 查找指定联系人信息
4. 修改指定联系人信息
5. 显示所有联系人信息
6.  清空所有联系人
7. 以名字排序所有联系人

没有开辟动态内存的方法:

头文件:test.h

#ifndef __CONTACT 
#define __CONTACT 
#define _CRT_SECURE_NO_WARNINGS 1 
#include<stdio.h> 
#include<stdlib.h> 
#include<string.h> 
#include<assert.h> 
#define N 1000 
typedef struct contact 
{ 
 char name[30]; 
 char gender[10]; 
 int age; 
 int telephone; 
 char address[100]; 
};//结构体没有定义变量属于声明一个结构体类型 
void meau(); 
void show(struct contact *p, int len);//struct contact *p:结构体指针指向这个结构体, int len:结构体数组的长度 
void Add_linkman(struct contact *p, int len,int flag); 
int Delete_linkman(struct contact *p, int d_number, int len);//int d_number选择要删除第几个结构体的内容 
void Find_member(struct contact *p, int d_number, int len);//int d_number表示要查找的第几个结构体的内容(即联系人的信息) 
void empty(struct contact *p); 
void Modify(struct contact *p, int M_member);//int M_member:要修改的第几个联系人 
int cmp(const void *a, const void *b);//qsort里面的比较函数定义任意类型 
void sort(struct contact *p, int len);//根据联系人的名字进行排序 
#endif//条件编译 

contact.c文件

#include"test.h" 
void meau() 
{ 
 printf("    *******************************************\n"); 
 printf("    *******************************************\n"); 
 printf("    ##############My address book##############\n"); 
 printf("    *1-Add  2-Delete  3-Find  *\n"); 
 printf("    *4-Empty  5-Modify  6-Sort  *\n"); 
 printf("    *0-Exit      7-Show  *\n"); 
 printf("    *******************************************\n"); 
 printf("    *******************************************\n"); 
} 
void show(struct contact *p, int len) 
{ 
 assert(p); 
 int i = 0; 
 for (i = 0; i < len; i++) 
 { 
  printf("name:%s gender:%s age:%d telephone:%d address:%s", \ 
   p[i].name, p[i].gender, p[i].age, p[i].telephone, p[i].address); 
  printf("\n"); 
 } 
} 
void Add_linkman(struct contact *p, int len,int flag) 
{ 
 assert(p); 
 int i = 0; 
 for (i = flag; i < len; i++) 
 { 
  printf("请输入姓名:"); 
  scanf("%s", &p[i].name); 
  printf("请输入姓别:"); 
  scanf("%s", &p[i].gender); 
  printf("请输入年龄:"); 
  scanf("%d", &p[i].age); 
  printf("请输入电话:"); 
  scanf("%d", &p[i].telephone); 
  printf("请输入地址:"); 
  scanf("%s", &p[i].address); 
 } 
} 
int Delete_linkman(struct contact *p, int d_number, int len) 
{ 
  
 assert(p); 
 int i = 0; 
 for (i = d_number - 1; i < len - 1; i++) 
 { 
  p[i] = p[i + 1]; 
 
 } 
} 
void Find_member(struct contact *p, int d_number, int len) 
{ 
 assert(p); 
 if (d_number - 1 >= 0 || d_number - 1<len) 
 { 
  printf("name:%s gender:%s age:%d telephone:%d address:%s", \ 
   p[d_number].name, p[d_number].gender, p[d_number].age, p[d_number].telephone, p[d_number].address); 
  printf("\n"); 
 } 
 else 
 { 
  printf("不存在该联系人:"); 
  return; 
 } 
 
} 
void empty(struct contact *p) 
{ 
 assert(p); 
 int i = 0; 
 for (i = 0; i <1000; i++) 
 { 
  memset(p+i, 0, sizeof(struct contact)); 
 } 
 
} 
void Modify(struct contact *p, int M_member) 
{ 
 assert(p); 
 printf("修改之前联系人的信息为:"); 
 printf("\n"); 
 printf("name:%s gender:%s age:%d telephone:%d address:%s", \ 
  p[M_member - 1].name, p[M_member - 1].gender, p[M_member - 1].age, p[M_member - 1].telephone, p[M_member - 1].address); 
 printf("\n"); 
 printf("请输入要修改的信息:"); 
 printf("请输入姓名:"); 
 scanf("%s", &p[M_member - 1].name); 
 printf("请输入姓别:"); 
 scanf("%s", &p[M_member - 1].gender); 
 printf("请输入年龄:"); 
 scanf("%d", &p[M_member - 1].age); 
 printf("请输入电话:"); 
 scanf("%d", &p[M_member - 1].telephone); 
 printf("请输入地址:"); 
 scanf("%s", &p[M_member - 1].address); 
 
} 
int cmp(const void *a, const void *b) 
{ 
 
 struct contact *aa = (struct contact *)a; 
 struct contact *bb = (struct contact *)b; 
 if (aa->name != bb->name) 
  return(strcmp((aa->name), (bb->name))); 
 
} 
void sort(struct contact *p, int len) 
{ 
 assert(p); 
 qsort(p, len, sizeof(struct contact), cmp); 
 
} 

test.c文件:

#include"test.h" 
int main() 
{ 
 int num = 0; 
 struct contact student[N]; 
 int len = 0; 
 int flag = 0;//定义一个标志位来结构体数组中每个结构体的位置 
 int total = N; 
 int delete_number = 0; 
 meau(); 
 while (1) 
 { 
  printf("请输入数字进行选择:"); 
  scanf("%d", &num); 
   switch (num) 
   { 
   case 1:{ 
      printf("请添加len个学生的信息:"); 
      scanf("%d", &len); 
      Add_linkman(student,len+flag,flag); 
      flag=flag+len; 
      
       
   }break; 
 
   case 2:{ 
      printf("请输入要删除的第i个学生的信息:"); 
      scanf("%d", &delete_number); 
      Delete_linkman(student, delete_number, len+flag); 
      flag = flag - 1; 
   }break; 
 
   case 3:{ 
      int Find_number = 0; 
      printf("请输入要查找的第i个学生的信息:"); 
      scanf("%d", &Find_number); 
      Find_member(student, delete_number, len+flag); 
 
   }break; 
 
   case 4:{ 
      printf("清空所有联系人:"); 
      empty(student); 
 
   }break; 
 
   case 5:{ 
      printf("请输入要修改的的第i个学生的信息:"); 
      int M_member = 0; 
      scanf("%d", &M_member); 
      Modify(student, M_member); 
 
   }break; 
 
   case 6:{ 
      printf("根据名字排序所有联系人:\n"); 
      sort(student, len+flag); 
 
   }break; 
 
   case 7:{ 
      printf("打印所有联系人的信息:\n"); 
      show(student, flag); 
 
   }break; 
   case 0:{ 
      exit(1); 
   } 
 
   default:printf("enter error data!!!"); 
 
  } 
 } 
 system("pause"); 
 return 0; 
 
} 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 详解C语言数组中是以列优先吗

    详解C语言数组中是以列优先吗

    这篇文章主要给大家介绍了关于C语言指针名称及所指变量的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用C语言具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-12-12
  • VC解析XML文件-CMarkup的使用详解

    VC解析XML文件-CMarkup的使用详解

    本篇文章是对VC解析XML文件-CMarkup的使用进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C++17文件系统库之std::filesystem 示例详解

    C++17文件系统库之std::filesystem 示例详解

    std::filesystem是C++17引入的一个强大且易用的文件系统操作库,它提供了跨平台的文件系统操作接口,简化了文件和目录操作的代码实现,本文给大家介绍C++17文件系统库之std::filesystem 示例详解,感兴趣的朋友一起看看吧
    2025-03-03
  • 详细解析命令行的getopt_long()函数

    详细解析命令行的getopt_long()函数

    getopt_long支持长选项的命令行解析,函数中的参数argc和argv通常直接从main()的两个参数传递而来
    2013-09-09
  • 基于Qt和Opencv实现二维码解析

    基于Qt和Opencv实现二维码解析

    这篇文章主要为大家详细介绍了如何利用 Qt 和 OpenCV 实现一个可从视频和图片中检测二维码的软件,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-11-11
  • C语言实现排序算法之归并排序详解

    C语言实现排序算法之归并排序详解

    这篇文章主要介绍了C语言实现排序算法之归并排序,对归并排序的原理及实现过程做了非常详细的解读,需要的朋友可以参考下
    2014-07-07
  • VC++实现CStdioFile写入及读取文件并自动换行的方法

    VC++实现CStdioFile写入及读取文件并自动换行的方法

    这篇文章主要介绍了VC++实现CStdioFile写入及读取文件并自动换行的方法,很实用的功能,需要的朋友可以参考下
    2014-08-08
  • 全局变量与局部变量在内存中的区别详细解析

    全局变量与局部变量在内存中的区别详细解析

    以下是对全局变量与局部变量在内存中的区别进行了详细的总结介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-10-10
  • C语言实现维吉尼亚密码的示例代码

    C语言实现维吉尼亚密码的示例代码

    维吉尼亚密码(又译维热纳尔密码)是使用一系列凯撒密码组成密码字母表的加密算法,属于多表密码的一种简单形式。本文将用C语言实现维吉尼亚密码,需要的可以参考一下
    2022-11-11
  • C语言实现餐饮点餐管理系统

    C语言实现餐饮点餐管理系统

    这篇文章主要为大家详细介绍了C语言实现餐饮点餐管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01

最新评论