news 2026/5/10 13:48:31

通讯管理系统

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
通讯管理系统
#include <stdio.h> #include <stdlib.h>//动态内存分配 #include <string.h> typedef struct Contact{ int id; char name[100]; char phone[100]; char email[100]; char group[100]; struct Contact*next; } Contact; //定义联系人结构体 typedef struct{ Contact*head; int count; int next_id; } AddressBook; //定义通讯录管理结构体 void initAddressBook(AddressBook*book){ book->head = NULL; book->count = 0; book->next_id = 1; } //初始化通讯录 void printMenu(){ printf("\n======================\n"); printf("\n====通讯录管理系统====\n"); printf("\n======================\n"); printf("\n======请选择操作======\n"); printf("1.添加联系人\n"); printf("2.显示联系人\n"); printf("3.搜索联系人\n"); printf("4.修改联系人\n"); printf("5.删除联系人\n"); printf("6.分组管理联系人\n"); printf("7.导出数据到文件 \n"); printf("8.导入数据\n"); printf("0.退出\n"); printf("\n请输入选项:"); } //打印菜单 void addContact(AddressBook*book){ printf("\n======添加联系人======\n"); Contact*newContact = (Contact*)malloc(sizeof(Contact)); if(newContact == NULL){ printf("内存分配失效!\n"); return; }//申请内存空间 newContact->id = book->next_id; book->next_id++;//给联系人编号 printf("请输入姓名:"); scanf("%s",newContact->name); printf("请输入电话:"); scanf("%s",newContact->phone); printf("请输入邮箱:"); scanf("%s",newContact->email); printf("请输入分组:"); scanf("%s",newContact->group);//获取用户输入 newContact->next = book->head; book->head = newContact; book->count++; printf("\n已成功添加联系人!ID:%d\n",newContact->id); } //添加联系人 void displayAllContacts(AddressBook*book){ printf("\n===所有联系人%d人===\n",book->count); if(book->count == 0) printf("通讯录为空\n"); else{ Contact*current = book->head; printf("ID\t姓名\t\t电话\t\t邮箱\t\t分组\n"); while(current!=NULL){ printf("%d\t%s\t\t%s\t\t%s\t\t%s\n", current->id,current->name,current->phone,current->email,current->group); current = current->next; } } } //显示所有联系人 void searchContact(AddressBook*book) { printf("\n====搜索联系人====\n"); printf("1.姓名搜索\n"); printf("2.电话搜索\n"); printf("3.分组搜索\n"); printf("请选择搜索方式:"); int choice; scanf("%d",&choice); char keyword[100]; printf("请输入关键词:"); scanf("%s",keyword); Contact*current = book->head; int found = 0; while(current!=NULL){ int match = 0; switch(choice){ case 1: if(strstr(current->name,keyword)!=NULL){ match = 1; } break; case 2: if(strstr(current->phone,keyword)!=NULL){ match = 1; } break; case 3: if(strcmp(current->group,keyword)==0){ match = 1; } break; } if(match){ if(!found){ printf("ID\t姓名\t\t电话\t\t邮箱\t\t分组\n"); found = 1; } printf("%d\t%s\t\t%s\t\t%s\t\t%s\n", current->id,current->name,current->phone,current->email,current->group); } current = current->next; } if(!found){ printf("未匹配到相关联系人\n"); } } //搜索联系人 void deleteContact(AddressBook*book){ printf("\n====删除联系人====\n"); if(book->count == 0){ printf("通讯录为空!\n"); return; } printf("请输入要删除的联系人ID:\n"); int id; scanf("%d",&id); Contact*current = book->head; Contact*prev = NULL; while(current != NULL && current->id != id){ prev = current; current = current->next; } if(current == NULL){ printf("未找出ID为%d的联系人",id); } else{ if(prev == NULL){ book->head = current->next; } else{ prev->next = current->next; } free(current); book->count--; printf("联系人删除成功!"); } } //删除联系人 void exportfile(AddressBook*book){ printf("\n====导出数据====\n"); char filename[100]; printf("请输入文件名:"); scanf("%s",filename); FILE*file = fopen(filename,"wb"); if(file == NULL){ printf("文件创建失败!\n"); return; } fwrite(&book->count,sizeof(int),1,file);//写入联系人数量 Contact*current = book->head; while(current!=NULL){ fwrite(current,sizeof(Contact),1,file); current = current->next;//写入每个联系人 } fclose(file); printf("数据导出成功!共导出%d个联系人到文件%s\n",book->count,filename); } //文件操作(导入、导出) int main(){ AddressBook book; initAddressBook(&book); int choice; do{ printMenu(); scanf("%d",&choice); switch(choice){ case 1: addContact(&book); break; case 2: displayAllContacts(&book); break; case 3: searchContact(&book); break; case 4: modifyContact(&book); break; case 5: deleteContact(&book); break; case 6: manageGroup(&book); break; case 7: exportfile(&book); break; case 8: importfile(&book); break; case 0: printf("\n退出系统ing...\n"); freeMemory(&book); break; default: printf("输入错误!请重新输入:"); break; } }while(choice!=0) return 0; } //主函数(程序入口)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/10 13:46:54

hash

lc

作者头像 李华
网站建设 2026/5/6 6:55:22

从数据湖到隐私湖:新一代数据架构思考

从数据湖到隐私湖&#xff1a;新一代数据架构的隐私原生进化 一、引言&#xff1a;当数据湖遇到“隐私危机” 1. 一个让企业胆战心惊的问题 你是否听说过**“数据湖变成‘数据沼泽’”**的说法&#xff1f; 过去十年&#xff0c;企业为了应对大数据浪潮&#xff0c;纷纷搭建数据…

作者头像 李华
网站建设 2026/4/30 22:56:23

SQL注入是什么?危害到底有多大?

SQL注入是什么&#xff1f;危害到底有多大&#xff1f; 近日&#xff0c;河南三门峡公安网安部门线上巡查发现&#xff0c;辖区内某公司的网站遭到网络攻击&#xff0c;首页内容被篡改为博彩页面。经查&#xff0c;该网站存在SQL注入漏洞&#xff0c;因未及时发现和修复&#…

作者头像 李华
网站建设 2026/5/9 4:52:03

朱炳仁、朱军岷14件铜艺捐赠入藏中国国家博物馆

2025年12月12日&#xff0c;朱炳仁、朱军岷作品捐赠入藏仪式在中国国家博物馆白玉厅隆重举行。这对国内罕见的“一门双国遗”父子传承人&#xff0c;将14件艺术珍品悉数捐赠给国博。这标志着朱炳仁首创的熔铜艺术&#xff0c;自2007年首件作品入藏国博后&#xff0c;历经18年沉…

作者头像 李华
网站建设 2026/5/3 9:41:21

数字化饮食闭环管理新趋势:AI技术如何重塑个性化营养方案

随着健康中国战略的深入推进&#xff0c;企业健康管理正迎来数字化转型升级的重要机遇。在员工健康管理领域&#xff0c;传统的饮食指导方式已难以满足精准化、个性化的需求。在此背景下&#xff0c;数字化饮食闭环管理作为一种创新模式&#xff0c;通过数据采集、智能分析、方…

作者头像 李华
网站建设 2026/5/3 11:24:34

AutoGPT+GPU云服务无限扩展的智能执行能力

AutoGPT 与 GPU 云服务&#xff1a;构建无限扩展的智能执行系统 在生成式 AI 的浪潮中&#xff0c;我们正经历一场从“对话工具”到“自主代理”的深刻变革。过去&#xff0c;用户需要一步步指导 AI 完成任务——“写一段介绍”、“搜索某项数据”、“总结这篇文档”。而今天&a…

作者头像 李华