用C语言实现简易通讯录

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

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

**提供方法:

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

思路分析:

首先我们可以分三个模块来解决这个问题,第一个模块我们需要一个头文件,这个头文件里可以包含一些相应信息,当实现文件和测试文件包含自己定义的头文件时便可以获得一些相关的信息。所以头文件里应该包括一个结构体,这个结构体里应包含姓名,性别,年龄,电话,住址。同时还可以定义一个结构体,这个结构体里包含通讯录,同时通讯录里人员的计数变量,将通讯录的地址传到别的地方便可以实现对它遍历或者其他操作。
第二个模块便是我们的测试函数,测试函数便可以实现我们的菜单打印,同时由我们接收不同的值便可以实现不同的操作,就是相应的方法的实现,这里很明显可以通过一个switch语句来进行控制。
第三个模块便是我们的方法实现的函数,将模块2里定义的类型为通讯录的地址传到各个方法里,这样便可以实现对通讯录的操作。
1.linkman.h(头文件)

#ifndef __LINKMAN_H__
#define __LINKMAN_H__

#include<stdio.h>
#include<windows.h>
#include<string.h>
#pragma warning (disable:4996)
typedef struct LINKMAN//建立结构体,存放联系人信息
{
  char name[20];
  char sex[10];
  int age;
  int tel[12];
  char addr[50];
}LINKMAN;

typedef struct Statis //把通讯录和人员统计放在结构体内
{
  LINKMAN num[1000];
  int count;
}Statis;

void inint_linkman(Statis *p);//初始化数组
void Add_linkman(Statis *p);// 添加联系人信息
void Dele_linkman(Statis *p);//删除指定联系人信息
void Find_linkman(Statis *p);//查找指定联系人信息
void Revise_linkman(Statis *p);//修改指定联系人信息
void Display_linkman(Statis *p);//显示所有联系人信息
void Empty_linkman(Statis *p);//清空所有联系人
void sort_linkman(Statis *p);//以名字排序所有联系人
#endif

2.test.c(测试)

#include "linkman.h"
Statis sta;
void menu()//菜单
{
  printf("***********************************\n");
  printf("********1.添加联系人信息***********\n");
  printf("********2.删除指定联系人信息*******\n");
  printf("********3.查找指定联系人信息*******\n");
  printf("********4.修改指定联系人信息*******\n");
  printf("********5.显示所有联系人信息*******\n");
  printf("********6.清空所有联系人***********\n");
  printf("********7.以名字排序所有联系人*****\n");
  printf("**************按0退出程序**********\n");
  printf("***********************************\n");

}

void test()
{
  int i = 0;
  do
  {
    menu();
    printf("请输入你要进行的选项:");
    scanf("%d", &i);
    switch (i)
    {
    case 1:
      Add_linkman(&sta);
      break;
    case 2:
      Dele_linkman(&sta);
      break;
    case 3:
      Find_linkman(&sta);
      break;
    case 4:
      Revise_linkman(&sta);
      break;
    case 5:
      Display_linkman(&sta);
      break;
    case 6:
      Empty_linkman(&sta);
      break;
    case 7:
      sort_linkman(&sta);
      break;
    case 0:
      exit(1);
      break;
    default:
      printf("输入错误\n");
      break;
    }
  } while (i);
}

int main()
{
  inint_linkman(&sta);
  test();
  system("pause");
  return 0;
}

3.game.c(实现)

#include "linkman.h"

void inint_linkman(Statis *p)
{
  int count = sizeof(p->num);
  p->count = 0;
  memset(p->num, 0,count);
}
int Find(Statis *p, char *pname)//对于一个联系人是否存在封装一个函数,在后面的修改、删除、查找可以用到
{
  int i = 0;
  for (i = 0; i < (p->count); i++)
  {
    if (strcmp(p->num[i].name, pname) == 0)
      return i;

  }
  return -1;
}

void menu1()//修改联系人时所用到的菜单
{
  printf("*********************\n");
  printf("****1.姓名*2.性别****\n");
  printf("****3.年龄*4.电话****\n");
  printf("****5.地址*6.返回****\n");
  printf("*********************\n");
}

void Add_linkman(Statis *p)//添加联系人
{
  printf("请输入你要添加的联系人姓名:\n");
  scanf("%s", p->num[p->count].name);
  printf("请输入你要添加的联系人性别:\n");
  scanf("%s", p->num[p->count].sex);
  printf("请输入你要添加的联系人年龄:\n");
  scanf("%d", &(p->num[p->count].age));
  printf("请输入你要添加的联系人电话:\n");
  scanf("%s", p->num[p->count].tel);
  printf("请输入你要添加的联系人地址:\n");
  scanf("%s", p->num[p->count].addr);
  if ((p->count) > 1000)
  {
    printf("联系人上限\n");
  }
  else
  {
    printf("添加成功\n");
    p->count++;
  }
}

void Dele_linkman(Statis *p)//删除联系人
{
  char name[20] = { 0 };
  int result = 0;
  int n = 0;
  int i = 0;
  printf("请输入要删除人的姓名:\n");
  scanf("%s", name);
  result = Find(p, name);
  if (result != -1)
  {
    printf("你是否要删除该联系人?\n");
    printf("删除请按1,不删除请按0\n");
    scanf("%d", &n);
    if (n == 1)
    {
      for (i = 0; i < (p->count)-1; i++)
      {
        p->num[i] = p->num[i + 1];
      }
      p->count --;
      printf("删除成功\n");
    }
    else
    {
      printf("删除失败\n");
    }
  }
  else
  {
    printf("你要删除的联系人不存在\n");
  }
}

void Find_linkman(Statis *p)//查找联系人
{
  char name[20] = { 0 };
  int result = 0;
  printf("请输入要查找联系人的姓名:\n");
  scanf("%s", name);
  result = Find(p, name);
  if (result != -1)
  {
    printf("姓名:%s\n", p->num[result].name);
    printf("性别:%s\n", p->num[result].sex);
    printf("年龄:%d\n", p->num[result].age);
    printf("电话:%s\n", p->num[result].tel);
    printf("地址:%s\n", p->num[result].addr);
  }
  else
  {
    printf("你要查找的联系人不存在\n");
  }
}

void Revise_linkman(Statis *p)//修改联系人
{
  char name[20] = {0};
  int result = 0;
  printf("请输入你要修改联系人的姓名:\n");
  scanf("%s", name);
  result = Find(p, name);
  if (result != -1)
  {
    printf("姓名:%s\n", p->num[result].name);
    printf("性别:%s\n", p->num[result].sex);
    printf("年龄:%d\n", p->num[result].age);
    printf("电话:%s\n", p->num[result].tel);
    printf("地址:%s\n", p->num[result].addr);
    int i = 0;
    do
    {
      menu1();
      printf("输入你要修改的选项:\n");
      scanf("%d", &i);
      switch (i)
      {
      case 1:
        printf("请把姓名修改成:");
        scanf("%s", p->num[result].name);
        break;
      case 2:
        printf("请把性别修改成:");
        scanf("%s", p->num[result].sex);
        break;
      case 3:
        printf("请把年龄修改成:");
        scanf("%d", &(p->num[result].age));
        break;
      case 4:
        printf("请把电话修改成:");
        scanf("%s", p->num[result].tel);
        break;
      case 5:
        printf("请把地址修改成:");
        scanf("%s", p->num[result].addr);
        break;
      case 0:
        break;
      default:
        printf("输入错误");
        break;
      }
    } while (i);
  }
  else
  {
    printf("你要修改的联系人不存在\n");
  }
}

void Display_linkman(Statis *p)//打印所有联系人信息
{
  int i = 0;
  printf("输出所有人的信息:\n");
  printf("%10s%7s%6s%8s%10s\n","名字","性别","年龄","电话","住址");
  for (i = 0; i <(p->count); i++)
  {
    printf("%11s", p->num[i].name);
    printf("%5s", p->num[i].sex);
    printf("%5d", p->num[i].age);
    printf("%10s", p->num[i].tel);
    printf("%12s", p->num[i].addr);
    printf("\n");
  }
}

void Empty_linkman(Statis *p)//清空联系人
{
  p->count = 0;
}

void sort_linkman(Statis *p)//以名字排序所有联系人(冒泡)
{
  int i = 0;
  int j = 0;
  for (i = 0; i < p->count - 1; i++)
  for (j = 0; j < p->count - 1 - i; j++)
  {
    if (strcmp(p->num[j].name, p->num[j + 1].name)>0)
    {
      LINKMAN tmp;
      tmp = p->num[j];
      p->num[j] = p->num[j + 1];
      p->num[j + 1] = tmp;
    }
  }
}

程序运行结果部分示范:

到此为止,我们的简易通讯录就实现啦!!!

您可能感兴趣的文章:

  • C语言通讯录管理系统课程设计
  • C语言通讯录管理系统完整版
  • C语言实现通讯录功能
  • C语言使用结构体实现简单通讯录
  • C语言通讯录实例分享
  • C语言实现一个通讯录
  • C语言实现通讯录系统
  • C语言实现简单的通讯录
  • 使用C语言打造通讯录管理系统和教学安排系统的代码示例
  • C语言基于哈希表实现通讯录
(0)

相关推荐

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

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

  • 使用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语言实现通讯录功能的具体代码,供大家参考,具体内容如下 先定义头文件 #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语言通讯录实例的具体代码,供大家参考,具体内容如下 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语言实现了通讯录的录入信息.保存信息.插入.删除.排序.查找.单个显示等功能.. 完整的代码如下: #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个人的信息,每个人的信息包括: 姓名.性别.年龄.电话.住址 提供方法: 1. 添加联系人信息 2. 删除指定联系人信息 3. 查找指定联系人信息 4. 修改指定联系人信息 5. 显示所有联系人信息 6. 清空所有联系人 代码实现: 头文件: #ifndef __HEAD_H__ ////防止头文件被多次调用 #define __HEAD_H__ #include<stdio.h> #include<string.h> #in

  • C语言实现一个通讯录

    实现一个通讯录,通讯录可以用来存储1000个人的信息,每个人的信息包括: 姓名.性别.年龄.电话.住址 提供方法: 1. 添加联系人信息 2. 删除指定联系人信息 3. 查找指定联系人信息 4. 修改指定联系人信息 5. 显示所有联系人信息 6.  清空所有联系人 7. 以名字排序所有联系人 没有开辟动态内存的方法: 头文件:test.h #ifndef __CONTACT #define __CONTACT #define _CRT_SECURE_NO_WARNINGS 1 #include<

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

随机推荐