C语言开发实现通讯录管理系统

本文实例为大家分享了C语言通讯录管理系统开发的具体代码,供大家参考,具体内容如下

程序介绍

通讯录管理系统主要是实现对联系人的增、删、查以及显示的基本操作。用户可以根据自己的需要在功能菜单中选择相应的操作,实现对联系人的快速管理。

操作流程

用户在编译完成后会产生一个系统的可执行文件,用户只要双击可执行文件就可以进入系统,进入系统的功能选择菜单,如图所示,用户根据自己的需要选择相应的操作。

代码

#include<stdio.h>
#include<stdlib.h>
#include<dos.h>
#include <conio.h>
#include<string.h>
struct Info
{
    char name[15];/*姓名*/
    char city[10];/*城市*/
    char province[10];/*省*/
    char state[10];/*国家*/
    char tel[15];/*电话*/
};
typedef struct node/*定义通讯录链表的结点结构*/
{
    struct Info data;
    struct node *next;
}Node,*link;

void stringinput(char *t,int lens,char *notice)
{
   char n[50];
   do{
      printf("%s",notice); /*显示提示信息*/
      scanf("%s",&n); /*输入字符串*/
      if(strlen(n)>lens)
          printf("\n exceed the required length! \n"); /*超过lens值重新输入*/
     }while(strlen(n)>lens);
   strcpy(t,n); /*将输入的字符串拷贝到字符串t中*/
}

void enter(link l)/*输入记录*/
{
    Node *p,*q;
    q=l;
    while(1)
    {
        p=(Node*)malloc(sizeof(Node));/*申请结点空间*/
        if(!p)/*未申请成功输出提示信息*/
        {
            printf("memory malloc fail\n");
            return;
        }
        stringinput(p->data.name,15,"enter name:");/*输入姓名*/
        if(strcmp(p->data.name,"0")==0)/*检测输入的姓名是否为0*/
            break;
        stringinput(p->data.city,10,"enter city:");/*输入城市*/
        stringinput(p->data.province,10,"enter province:");/*输入省*/
        stringinput(p->data.state,10,"enter status:");/*输入国家*/
        stringinput(p->data.tel,15,"enter telephone:");/*输入电话号码*/
        p->next=NULL;
        q->next=p;
        q=p;
    }
}

void del(link l)
{
    Node *p,*q;
    char s[20];
    q=l;
    p=q->next;
    printf("enter name:");
    scanf("%s",s);/*输入要删除的姓名*/
    while(p)
    {
        if(strcmp(s,p->data.name)==0)/*查找记录中与输入名字匹配的记录*/
        {
            q->next=p->next;/*删除p结点*/
            free(p);/*将p结点空间释放*/
            printf("delete successfully!");
            break;
        }
        else
        {
            q=p;
            p=q->next;
        }
    }
    getch();
}
void display(Node *p)
{
    printf("MESSAGE \n");
    printf("name:%15s\n",p->data.name);
    printf("city:    %10s\n",p->data.city);
    printf("province:%10s\n",p->data.province);
    printf("state:   %10s\n",p->data.state);
    printf("telphone:%15s\n",p->data.tel);
    
}
void search(link l)
{
    char name[20];
    Node *p;
    p=l->next;
    printf("enter name to find:");
    scanf("%s",name);/*输入要查找的名字*/
    while(p)
    {
        if(strcmp(p->data.name,name)==0)/*查找与输入的名字相匹配的记录*/
        {
            display(p);/*调用函数显示信息*/
            getch();
            break;
        }
        else
        p=p->next;
    }
}
void list(link l)
{
    Node *p;
    p=l->next;
    while(p!=NULL)/*从首节点一直遍历到链表最后*/
    {
        display(p);
        p=p->next;
    }
    getch();
}

void save(link l)
{
    Node *p;
    FILE *fp;
    p=l->next;
    if((fp=fopen("f:\\adresslist","wb"))==NULL)
    {
        printf("can not open file\n");
        exit(1);
    }
    printf("\nSaving file\n");
    while(p)/*将节点内容逐个写入磁盘文件中*/
    {
        fwrite(p,sizeof(Node),1,fp);
        p=p->next;
    }
    fclose(fp);
    getch();
}
void load(link l)
{
    Node *p,*r;
    FILE *fp;
    l->next=NULL;
    r=l;
    if((fp=fopen("f:\\adresslist","rb"))==NULL)
    {
        printf("can not open file\n");
        exit(1);
    };
    printf("\nLoading file\n");
    while(!feof(fp))
    {
        p=(Node*)malloc(sizeof(Node));/*申请节点空间*/
        if(!p)
        {
            printf("memory malloc fail!");
            return;
        }
        if(fread(p,sizeof(Node),1,fp)!=1)/*读记录到节点p中*/
        break;
        else
        {
            p->next=NULL;
            r->next=p;/*插入链表中*/
            r=p;
        }
    }
    fclose(fp);
    getch();
}

int menu_select()
{
    int i;
    printf("\n\n\t *************************ADDRESS LIST*************************\n");
    printf("\t|*            1.input record                  *|\n");
    printf("\t|*            2.delete record                  *|\n");
    printf("\t|*            3.list record                  *|\n");
    printf("\t|*            4.search record                  *|\n");
    printf("\t|*            5.save record                  *|\n");
    printf("\t|*            6.load record                  *|\n");
    printf("\t|*            7.Quit                                *|\n");
    printf("\t **************************************************************\n");
    do
    {
        printf("\n\tEnter your choice:");
        scanf("%d",&i);
    }while(i<0||i>7);
    return i;
}
main()
{
    link l;
    l=(Node*)malloc(sizeof(Node));
    if(!l)
    {
        printf("\n allocate memory failure "); /*如没有申请到,输出提示信息*/
        return 0;             /*返回主界面*/
    }
    l->next=NULL;
    system("cls");
    while(1)
    {
        system("cls");
        switch(menu_select())
        {
            case 1:
                enter(l);
                break;
            case 2:
                del(l);
                break;
            case 3:
                list(l);
                break;
            case 4:
                search(l);
                break;
            case 5:
                save(l);
                break;
            case 6:
                load(l);
                break;
            case 7:
                exit(0);
        }
    }
}

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

(0)

相关推荐

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

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

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

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

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

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

  • C语言实现个人通讯录管理系统

    如何用c语言制作简易的个人通讯录管理系统?想必这是每一位初步学习c语言的同学需要解决的一个大问题.如何将这些数据类型不完全相同的数据元素存储并访问呢?采用结构体便能轻松解决这个问题! #include<stdio.h> #include<string.h> #include<stdlib.h> #include<windows.h> struct stu //第一部分:声明结构体类型struct stu { char name[100];//姓名为字符串型

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

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

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

随机推荐