实现一个通讯录

实现一个通讯录;

通讯录可以用来存储1000个人的信息,每个人的信息包括:
姓名、性别、年龄、电话、住址

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

实现起来并不是很难,但是一定要养成良好的代码习惯。

Contact.h

#pragma once

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

enum OPTION
{
    EXIT,
    ADD,
    DEL,
    SEARCH,
    MODIFY,
    SHOW,
    EMPTY,
    SORT
};

#define MAX_NAME 20
#define MAX_SEX 5
#define MAX 1000
#define MAX_TEL 12

typedef struct PeoInfo
{
    char name[MAX_NAME];
    int age;
    char sex[MAX_SEX];
    char tel[MAX_TEL];

}PeoInfo;

typedef struct  Contact
{
    PeoInfo data[MAX];
    int count;
}Contact, *pContact;

void InitContact(pContact pc);
void AddContact(pContact pc);
void DelContact(pContact pc);
void SearchContact(pContact pc);
void ModifyContact(pContact pc);
void ShowContact(pContact pc);
void EmptyContact(pContact pc);
void SortContact(pContact pc);

Contact.c

#define _CRT_SECURE_NO_WARNINGS 1

#include"Contact.h"
void InitContact(pContact pc)
{
    pc->count = 0;
    memset(pc->data, 0, sizeof(pc->data));
}

void AddContact(pContact pc)
{
    if (pc->count == MAX)
    {
        printf("请注意,通讯录已满\n");
        return;
    }
    printf("请输入名字:>");
    scanf("%s",&( pc->data[pc->count].name));
    printf("请输入年龄:>");
    scanf("%d",&( pc->data[pc->count].age));
    printf("请输入性别:>");
    scanf("%s", &(pc->data[pc->count].sex));
    printf("s", &(pc->data[pc->count].tel));
    pc->count++;
}
int FindEntry(char name[], pContact pc)
{
    int i = 0;
    for (i = 0; i < pc->count; i++)
    {
        if (strcmp(pc->data[i].name, name) == 0)
        {
            return i;
        }
    }
    return -1;
}
void DelContact(pContact pc)
{
    char name[MAX_NAME] = { 0 };
    int pos = 0;
    int i = 0;
    if (pc->count == 0)
    {
        printf("通讯录为空\n");
        return;
    }
    printf("请输入姓名:>");
    scanf("%s", name);
    pos = FindEntry(name,pc);
    if (pos == -1)
    {
        printf("要删除的人不存在\n");
        return;
    }
    for (i = pos; i < pc->count-1; i++)
    {
        pc->data[i] = pc->data[i + 1];
    }
    pc->count--;
    printf("删除成功\n");
}
void SearchContact(pContact pc)
{
    if (pc->count == 0)
    {
        printf("通讯录为空\n");
        return;
    }
    char name[MAX_NAME] = { 0 };
    int pos = 0;
    printf("请输入需要查找的人的姓名:>");
    scanf("%s", name);
    pos = FindEntry(name, pc);
    if (pos == -1)
    {
        printf("查找的人不存在\n");
        return;
    }
    printf("%s %d %s %s\n", pc->data[pos].name, pc->data[pos].age, pc->data[pos].sex, pc->data[pos].tel);
}
void ModifyContact(pContact pc)
{
    if (pc->count == 0)
    {
        printf("通讯录为空\n");
        return;
    }
    char name[MAX_NAME] = { 0 };
    int pos = 0;
    printf("请输入需要修改的人的姓名:>");
    scanf("%s", name);
    pos = FindEntry(name, pc);
    if (pos == -1)
    {
        printf("修改的人不存在\n");
        return;
    }
    printf("姓名修改为:>");
    scanf("%s", pc->data[pos].name);
    printf("年龄修改为:>");
    scanf("%d", &(pc->data[pos].age));
    printf("性别修改为:>");
    scanf("%s", pc->data[pos].sex);
    printf("电话修改为:>");
    scanf("%s", pc->data[pos].tel);
    printf("%s %d %s %s\n", pc->data[pos].name, pc->data[pos].age, pc->data[pos].sex, pc->data[pos].tel);
    printf("修改成功\n");
}
void EmptyContact(pContact pc)
{
    InitContact(pc);
    printf("清空成功\n");
}
void ShowContact(pContact pc)
{
    int i = 0;
    if (pc->count == 0)
    {
        printf("通讯录为空\n");
        return;
    }
    for (i = 0; i < pc->count; i++)
    {
        printf("%s %d %s %s\n", pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tel);
    }
    printf("---------------------------------\n");
}
void SortContact(pContact pc)
{
    if (pc->count == 0)
    {
        printf("通讯录为空\n");
        return;
    }
    int i = 0;
    int j = 0;
    for (i = 0; i < pc->count - 1; i++)
    {
        for (j = 0; j < pc->count -i - 1; j++)
        {
            if (strcmp(pc->data[j].name, pc->data[j + 1].name) > 0)
            {
                PeoInfo tmp = pc->data[j];
                pc->data[j] = pc->data[j + 1];
                pc->data[j + 1] = tmp;
            }
        }
    }
    printf("排序成功\n");
    ShowContact(pc);
}

test.c

#define _CRT_SECURE_NO_WARNINGS 1

//#include <stdio.h>
//#include <stdlib.h>
//
//int main()
//{
//  enum Color
//  {
//      a,
//      b,
//      c,
//  }abc;
//  printf("%d\n", sizeof(abc));
//  /*union
//  {
//      int i;
//      char a[2];
//  }*p,u;
//  p = &u;
//  p->a[0] = 0x39;
//  p->a[1] = 0x38;
//  printf("%d\n", sizeof(u));
//  printf("%x", p->i);*/
//
//  system("pause");
//  return 0;
//}

#include "Contact.h"

void menu()
{
    printf("*****************************************\n");
    printf("*****  1. 添加        2. 删除       *****\n");
    printf("*****  3. 查找        4. 修改       *****\n");
    printf("*****  5. 显示        6. 清空       *****\n");
    printf("****** 7. 排序        0. 退出       *****\n");
    printf("*****************************************\n");
}


int main()
{
    int input = 0;
    Contact my_con;
    InitContact(&my_con);
    do
    {
        menu();
        printf("请选择:>");
        scanf("%d", &input);
        switch (input)
        {
        case ADD:
            AddContact(&my_con);
            break;
        case DEL:
            DelContact(&my_con);
            break;
        case SEARCH:
            SearchContact(&my_con);
            break;
        case MODIFY:
            ModifyContact(&my_con);
            break;
        case SHOW:
            ShowContact(&my_con);
            break;
        case EMPTY:
            EmptyContact(&my_con);
            break;
        case SORT:
            SortContact(&my_con);
            break;
        default:
            break;
        }
    } while (input);

    system("pause");
    return 0;
}

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值