c语言实现通讯录(malloc版)

提供方法: 

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

7. 以名字排序所有联系人

头文件test.h

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


typedef struct P{
    char name[64];
    char tel[12];
}P;
void face();  //界面
void AddAContact();  //添加一个联系人
void DeleteAContact(const char *n, const char *t);  //删除一个联系人
void SearchAContact(const char *name);  //查找一个联系人
int ModifyAContact(const char* p);  //修改指定联系人信息
void ShwAllContact();     //显示所有人信息
void EmptyAllContact();     //清空所有人信息
void SortAllContact();        //所有人按照名字排序
#define _TEST_H
#endif

头文件实现test.c

#include"test.h"

P* Peo[1000];
int i = 0;

void face()
{
    printf("_____________________________________\n");
    printf("|***********************************|\n");
    printf("|              welcome!             |\n");
    printf("|***********************************|\n");
    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");
}

添加联系人当人满1000时,不能继续添加,直接返回,提醒保存失败,当操作成功是i++


void AddAContact()
{
    if(i >= 1000)
    {
        printf("内存已满,无法继续保存!");
        return;
    }
    Peo[i] = malloc(sizeof(P));
    printf("请输入姓名:>");
    scanf("%s",Peo[i]->name);
    printf("请输入电话号码:>");
    scanf("%s",Peo[i]->tel);
    Peo[i]->tel[11] = 0;
    printf("操作成功!\n");
    i++;
}

删除联系人时,通讯录没有联系人时,不能删除直接返回,n,t指针为空时,传入错误,直接返回,操作成功时,i--,没有找到联系人,删除失败,直接返回

void DeleteAContact(const char *n, const char *t)
{
    if(i == 0)
    {
        printf("没有联系人,不能删除\n");
        return;
    }
    if(n == NULL || t == NULL)
    {
	printf("输入错误!\n");
	return;
    }
    int k = 0;
    int j = 0;
    while(strcmp(n, Peo[k]->name) || strcmp(t, Peo[k]->tel))
    {
        k++;
        if(k == i)
        {
            printf("没有找到此联系人\n");
            return;
        }
    }

    for(j = 0; j < 64; j++)
    {
        Peo[k]->name[j] = 0;
    }
    for(j = 0; j < 12; j++) 
    {
        Peo[k]->tel[j] = 0;
    }
    free(Peo[k]);
    Peo[k] = NULL;

    while(k < i-1)
    {
        Peo[k] = Peo[k+1];
        k++;
    }
    i--;
    Peo[i] == NULL;
    printf("操作成功\n");
}

name指正不能为空,操作成功时,输出这位联系人的电话号码,没找到这个联系人时,提示未找到并返回


void SearchAContact(const char *name)
{
    if(name == NULL)
    {
        printf("请输入正确的姓名\n");
        return;
    }
    int j = 0;
    for(j=0; j<i; j++)
    {
        if(strcmp(name,Peo[j]->name) == 0 )
        {
            printf("这位联系人的电话号码: %s\n",Peo[j]->tel);
            printf("操作成功\n");
            return;
        }
    }
    printf("not find the contact!\n");
}

P指针不能为空,找到该联系人时,可修改姓名和电话号码,没找到这位联系人时,返回

void ModifyAContact(const char* p)
{
    if(p == NULL)
    {
        return ;
    }

    int j = 0;

    for(; j < i; j++)
    {
        if((strcmp(p, Peo[j]->name) == 0) || strcmp(p, Peo[j]->tel) == 0)
        {
            printf("找到了此联系人,请输入新信息\n");
            printf("姓名:");
            scanf("%s",Peo[j]->name);
            printf("电话号码:");
            scanf("%s",Peo[j]->tel);
            printf("操作成功\n");
        }
    }
    printf("没有找到此联系人\n");
}

显示所有联系人

void ShowAllContact()
{
    int j = 0;
    
    printf("---------------------------------------------\n");
    for(; j < i; j++)
    {
        printf("Name is %s\n", Peo[j]->name);
        printf("tel is %s\n", Peo[j]->tel);
        printf("---------------------------------------------\n");
    }
}

清空所有联系人,即释放所有空间

void EmptyAllContact()
{
    while(i>0)
    {
        free(Peo[i-1]);
        Peo[i-1] = NULL;
        i--;
    }
}

排序,以名字的第一个字母排序


static void swop(P *a,P *b)
{
    P *peo = malloc(sizeof(P));
    
    strcpy(peo->name, a->name);
    strcpy(peo->tel, a->tel);
    strcpy(a->name, b->name);
    strcpy(a->tel, b->tel);
    strcpy(b->name, peo->name);
    strcpy(b->tel, peo->tel);
    free(peo);
}

void SortAllContact()
{
    int j = 0;
    int k = 0;
    int flag = 0;
    for(; j<i; j++)
    {
        for(k=j; k<i; k++)
            {
            if(Peo[j]->name[0] > Peo[k]->name[0])
            {
             swop(Peo[j],Peo[k]);
            }
        }
    }
}

测试文件main.c

#include"test.h"

int main()
{
    int n = 0;
    while(1)
    {
        face();
        printf("请选择(0~7):>");    
        scanf("%d",&n);
        while(n > 7 || n < 0)
        {
            printf("enter error!\n");    
            printf("pleace choose(0~7):>");    
            scanf("%d",&n);
        }
        switch(n)
        {
            case 0:
                return 0;
            break;
            
            case 1:
                AddAContact();
            break;
            
            case 2:
                DeleteAContact("Bob","18165151223");
            break;
            
            case 3:
                SearchAContact("Bob");
            break;
            
            case 4:
                ModifyAContact("Bob");
            break;
            
            case 5:
                ShowAllContact();
            break;
            
            case 6:
                EmptyAllContact();
            break;
            
            case 7:
                SortAllContact();
            break;
            default:
            break;
        }
    }
    return 0;
}

Makefile:

test:*.c
	gcc -g $^ -o $@
.PHONY:clean
clean:
	rm tes

测试结果:


界面效果


添加几个联系人



查看刚才输入的联系人信息



排序后查看联系人



查询Bob的电话号码



修改Bob的信息



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值