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; 

} 

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

(0)

相关推荐

  • 用C语言实现简易通讯录

    C语言实现一个通讯录,通讯录可以用来存储1000个人的信息,每个人的信息包括: 姓名.性别.年龄.电话.住址 **提供方法: 1. 添加联系人信息 2. 删除指定联系人信息 3. 查找指定联系人信息 4. 修改指定联系人信息 5. 显示所有联系人信息 6. 清空所有联系人 7. 以名字排序所有联系人** 思路分析: 首先我们可以分三个模块来解决这个问题,第一个模块我们需要一个头文件,这个头文件里可以包含一些相应信息,当实现文件和测试文件包含自己定义的头文件时便可以获得一些相关的信息.所以头文件里

  • C语言使用结构体实现简单通讯录

    C语言用结构体实现一个通讯录,通讯录可以用来存储1000个人的信息,每个人的信息包括: 姓名.性别.年龄.电话.住址 提供方法: 1. 添加联系人信息 2. 删除指定联系人信息 3. 查找指定联系人信息 4. 修改指定联系人信息 5. 显示所有联系人信息 6. 清空所有联系人 代码实现: 头文件: #ifndef __HEAD_H__ ////防止头文件被多次调用 #define __HEAD_H__ #include<stdio.h> #include<string.h> #in

  • C语言通讯录实例分享

    本文实例为大家分享了C语言通讯录实例的具体代码,供大家参考,具体内容如下 main.c文件: // // main.c // c语言通讯录 // // Created by stevenchang on 9/6/15. // Copyright (c) 2015 cz. All rights reserved. // /** 1.添加联系人 2.删除联系人 3.更新联系人 4.显示所有联系人 5.查找联系人 6.退出系统 */ #include <stdio.h> int main(int a

  • C语言实现通讯录功能

    本文实例为大家分享了C语言实现通讯录功能的具体代码,供大家参考,具体内容如下 先定义头文件 #ifndef __CONTACT_H__ #define __CONTACT_H__ #define NAME_LEN 10 #define SEX_LEN 6 #define TELE_LEN 12 #define ADDR_LEN 20 #define MAX_PEO 1000 typedef struct PEO { char name[NAME_LEN]; int age; char sex[S

  • C语言实现通讯录系统

    C语言通讯录系统实现,供大家参考,具体内容如下 需求分析: 利用文件读,写的方法 实现增加通讯录联系人信息 实现删除通讯录联系人信息 实现查找通讯录联系人信息 实现修改通讯录联系人信息 实现查看现有通讯录联系人信息 代码实现: // main.c // C语言通讯录实现 // // Created by Brisinga on 15/10/14. // Copyright © 2015年 yan. All rights reserved. // #include <stdio.h> #incl

  • C语言通讯录管理系统完整版

    C语言实现了通讯录的录入信息.保存信息.插入.删除.排序.查找.单个显示等功能.. 完整的代码如下: #include <stdio.h> #include <malloc.h> //得到指向大小为Size的内存区域的首字节的指针// #include <string.h> #include <stdlib.h> //标准库函数// #define NULL 0 #define LEN sizeof(struct address_list) //计算字节//

  • C语言通讯录管理系统课程设计

    本文实例为大家分享了C语言通讯录管理系统课程设计,供大家参考,具体内容如下 #include <stdio.h> #include <stdlib.h> #include <windows.h> struct Sign{ char name[8]; char sex[4]; char birthday[12]; char phone[11]; char postcode[7]; char addr[30]; struct Sign *next; }pe; char Ph

  • C语言实现简单的通讯录

    用C语言写了一个简单的通讯录,说简单一是功能简单,二是也没有加读写文件操作,只是作为链表操作的一个练习,希望能给这方面的新手一此引导和帮助. 代码: /* 转贴请注明出处 */ /* 作者:小浦原(ID:blueboy82006) */ /* http://blog.csdn.net/blueboy82006 */ #include <stdio.h> #include <stdlib.h> #include<string.h> #include<ctype.h&

  • C语言基于哈希表实现通讯录

    本文为大家分享了C语言基于哈希表实现通讯录的具体代码,供大家参考,具体内容如下 1.需求分析 本演示程序用C语言编写,完成哈希表的生成,电话号码的插入.以及查找等功能. (1)按提示输入相应的联系人的相关资料: (2)以相应的输出形式输出所存储的的联系人的资料: (3)程序可以达到建立.添加.查找.打印的功能: (4)程序可以判断用户输入的非法数据并引导正确的输入. 2.概要设计 存储电话号码的记录时,若在存储位置和其关键字之间建立某种确定的对应关系使得每个关键字和存储结构中一个唯一的存储位置相

  • 使用C语言打造通讯录管理系统和教学安排系统的代码示例

    通讯录管理系统 实现了通讯录的录入信息.保存信息.插入.删除.排序.查找.单个显示等功能.. 完整的代码如下: #include <stdio.h> #include <malloc.h> //得到指向大小为Size的内存区域的首字节的指针// #include <string.h> #include <stdlib.h> //标准库函数// #define NULL 0 #define LEN sizeof(struct address_list) //计

  • 利用C语言结构体实现通讯录

    本文实例为大家分享了C语言结构体实现通讯录的具体代码,供大家参考,具体内容如下 用来存储1000个人的信息的通讯录,每个人的信息包括: 姓名.性别.年龄.电话.住址 程序如下: #include<stdio.h> #include<string.h> #include<stdlib.h> struct People { char name[20]; char sex[5]; int age; char tel[15]; char addr[50]; }; //定义人的信

随机推荐