当前位置 : 主页 > 编程语言 > c语言 >

通讯录实现

来源:互联网 收集:自由互联 发布时间:2023-09-07
主程序 #define _CRT_SECURE_NO_WARNINGS 1 #include"contact.h" void menu() { printf("*************************************\n"); printf("*******1.add 2.del***********\n"); printf("*******3.search 4.modify********\n"); printf("*******5.show

主程序

#define _CRT_SECURE_NO_WARNINGS 1

#include"contact.h"


void menu()

{

printf("*************************************\n");

printf("*******1.add         2.del***********\n");

printf("*******3.search      4.modify********\n");

printf("*******5.show        6.sort**********\n");

printf("*******0.exit************************\n");

printf("*************************************\n");

}



int main()

{

int input = 0;

//创建通讯录

struct Contact con;

//初始化通讯录

InitContact(&con);//结构体传参,最好传地址,可修改,效率高

do

{

 menu();

 printf("请选择:>");

 scanf("%d", &input);

 switch (input)

 {

 case ADD:

  AddContact(&con);//增加函数

  break;

 case DEL:

  DelContact(&con);

  break;

 case SEARCH:

  break;

 case MDDIFY:

  ModifyContact(&con);

  break;

 case SHOW:

  ShowContact(&con);//传地址只传4个字节,也传地址

  break;

 case SORT:

  break;

 case EXIT:

  printf("退出通讯录\n");

  break;

 default:

  printf("选择错误\n");

  break;

 }

} while (input);

return 0;

}


函数声明

#define _CRT_SECURE_NO_WARNINGS 1


#define MAX 1000


#define MAX_NAME 20

#define MAX_SEX 5

#define MAX_TELE 12

#define MAX_ADDR 30


#include<stdio.h>

#include<string.h>


enum Option//枚举选项 可读性增高

//作用点,声明case后面名字的出处

{

EXIT,//默认从0开始

ADD,

DEL,

SEARCH,

MDDIFY,

SHOW,

SORT

};


struct PeoInfo//一个人的信息类型

{

char name[MAX_NAME];

int age;

char sex[MAX_SEX];

char tele[MAX_TELE];

char addr[MAX_ADDR];

};


struct Contact//通讯录类型

{

struct PeoInfo data[MAX];//存放多少个人的信息data

int size;//记录当前已有的个数size

};


//初始化函数

void InitContact(struct Contact* ps);

//增加函数

void AddContact(struct Contact* ps);

//显示函数

void ShowContact(const struct Contact* ps);

//删除指定联系人

void DelContact(struct Contact* ps);

//查找指定人的信息

void SearchContact(struct Contact* ps);

//修改指定联系人

void ModifyContact(struct Contact* ps);



函数定义

#define _CRT_SECURE_NO_WARNINGS 1


#include"contact.h"


void InitContact(struct Contact * ps)

{

//memset设置内存

memset(ps->data, 0, sizeof(ps->data));//data是个数组

ps->size = 0;//size是几个元素

}


void AddContact(struct Contact *ps)

{

if (ps->size == MAX)//超过MAX就满了

{

 printf("通讯录已满,无法添加\n");

}

else

{

 printf("请输入名字:>");

 scanf("%s", ps->data[ps->size].name);//名字是一个数组

 //data数组的第size个值

 printf("请输入年龄:>");

 scanf("%d", &(ps->data[ps->size].age));//年龄是一个值,要取地址

 printf("请输入性别:>");

 scanf("%s", ps->data[ps->size].sex);

 printf("请输入电话:>");

 scanf("%s", ps->data[ps->size].tele);

 printf("请输入住址:>");

 scanf("%s", ps->data[ps->size].addr);

 ps->size++;//元素个数也发生变化

 printf("添加成功\n");

}

}


void ShowContact(const struct Contact * ps)

{

if (ps->size == 0)

{

 printf("通讯录为空格\n");

}

else

{

 int i = 0;

 printf("%20s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年龄", "性别", "电话", "地址");

 //%4s就是打印4个字符

 for (i = 0; i < ps->size; i++)

 {

  printf("%20s\t%4d\t%5s\t%12s\t%20s\n",//年龄用%4d是整数

   ps->data[i].name,

   ps->data[i].age,

   ps->data[i].sex,

   ps->data[i].tele,

   ps->data[i].addr);

 }

}

}


static int FindByName(const struct Contact * ps, char name[MAX_NAME])

//这个函数写在.c文件里是因为这是一个辅助函数,不是功能函数

{

int i = 0;

for (i = 0; i < ps->size; i++)

{

 if (0 == strcmp(ps->data[i].name, name))

 {

  return i;//找到的情况

 }

}

return -1;//找不到的情况

}


void DelContact(struct Contact * ps)

{

char name[MAX_NAME];

printf("请输入要删除人的名字:>");

scanf("%s", name);

//1.查找要删除的人在什么位置

//找到了返回名字所在的元素下标

//找不到返回-1

int pos = FindByName(ps, name);

//2.删除

if (pos==-1)

{

 printf("要删除的人不存在\n");

}

else

{

 int j = 0;

 for (j = pos; j < ps->size - 1; j++)//到最后一个元素之前一个元素就行

 {

  ps->data[j] = ps->data[j + 1];//从后往前复制

 }

 ps->size--;

 printf("删除成功\n");

}

}


void SearchContact(struct Contact * ps)

{

char name[MAX_NAME];

printf("请输入查找人的名字:>");

scanf("%s", name);

int pos = FindByName(ps, name);

if (pos == -1)

{

 printf("要查找的人不存在\n");

}

else

{

 int i = 0;

 printf("%20s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年龄", "性别", "电话", "地址");

 for (i = 0; i < ps->size; i++)

 {

  printf("%20s\t%4d\t%5s\t%12s\t%20s\n",

   ps->data[pos].name,

   ps->data[pos].age,

   ps->data[pos].sex,

   ps->data[pos].tele,

   ps->data[pos].addr);

 }

}

}


void ModifyContact(struct Contact * ps)

{

char name[MAX_NAME];

printf("请输入查找人的名字:>");

scanf("%s", name);

int pos = FindByName(ps, name);

if (pos == -1)

{

 printf("要修改的人不存在\n");

}

else

{

  printf("请输入名字:>");

  scanf("%s", ps->data[pos].name);//名字是一个数组

  printf("请输入年龄:>");

  scanf("%d", &(ps->data[pos].age));//年龄是一个值

  printf("请输入性别:>");

  scanf("%s", ps->data[pos].sex);

  printf("请输入电话:>");

  scanf("%s", ps->data[pos].tele);

  printf("请输入住址:>");

  scanf("%s", ps->data[pos].addr);

  ps->size++;

  printf("修改成功\n");

}

}

【文章转自 响水网站设计 http://www.1234xp.com/xiangshui.html 欢迎留下您的宝贵建议】
上一篇:数据结构--&gt;二叉树_OJ_03
下一篇:没有了
网友评论