如何用C语言设计并实现高效的通讯管理系统?

2026-05-20 20:421阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1646个文字,预计阅读时间需要7分钟。

如何用C语言设计并实现高效的通讯管理系统?

本文实例展示了如何使用C语言实现通讯管理系统。以下为具体代码示例,供大家参考:

c#include #include

// 定义通讯录结构体typedef struct { char name[50]; char phone[20];} Contact;

// 函数声明void addContact(Contact *contacts, int *count);void deleteContact(Contact *contacts, int *count);void listContacts(const Contact *contacts, int count);void searchContact(const Contact *contacts, int count);

int main() { Contact contacts[100]; // 通讯录数组,最多存储100个联系人 int count=0; // 当前通讯录中联系人的数量

// 主循环,根据用户输入执行相应操作 while (1) { printf(1. 添加联系人\n); printf(2. 删除联系人\n); printf(3. 列出所有联系人\n); printf(4. 搜索联系人\n); printf(5. 退出\n); printf(请输入操作编号:); int choice; scanf(%d, &choice);

switch (choice) { case 1: addContact(contacts, &count); break; case 2: deleteContact(contacts, &count); break; case 3: listContacts(contacts, count); break; case 4: searchContact(contacts, count); break; case 5: return 0; default: printf(无效的操作编号,请重新输入。\n); } }

return 0;}

// 添加联系人函数void addContact(Contact *contacts, int *count) { if (*count >=100) { printf(通讯录已满,无法添加更多联系人。\n); return; }

printf(请输入联系人姓名:); scanf(%s, contacts[*count].name); printf(请输入联系人电话:); scanf(%s, contacts[*count].phone); (*count)++; printf(联系人添加成功!\n);}

// 删除联系人函数void deleteContact(Contact *contacts, int *count) { if (*count==0) { printf(通讯录为空,无法删除联系人。\n); return; }

char name[50]; printf(请输入要删除的联系人姓名:); scanf(%s, name);

for (int i=0; i < *count; i++) { if (strcmp(contacts[i].name, name)==0) { for (int j=i; j < *count - 1; j++) { contacts[j]=contacts[j + 1]; } (*count)--; printf(联系人删除成功!\n); return; } }

printf(未找到该联系人。\n);}

// 列出所有联系人函数void listContacts(const Contact *contacts, int count) { if (count==0) { printf(通讯录为空。\n); return; }

printf(通讯录如下:\n); for (int i=0; i

// 搜索联系人函数void searchContact(const Contact *contacts, int count) { if (count==0) { printf(通讯录为空。\n); return; }

char name[50]; printf(请输入要搜索的联系人姓名:); scanf(%s, name);

for (int i=0; i

printf(未找到该联系人。\n);}

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

#include<stdio.h> #include<string.h> #include<stdlib.h> typedef struct{ char num[5]; char name[9]; char sex[9]; char phone[13]; char addr[31]; }DataType; typedef struct node{ DataType data; struct node*next; } ListNode, *LinkList; LinkList head; ListNode *p; int menu_select(); LinkList CreateList(void); void InsertNode(LinkList head,ListNode *p); ListNode *ListFind(LinkList head); void DelNode(LinkList head); void printList(LinkList head); void ChangeNode(LinkList head); int main(void){ for(; ;){ switch(menu_select()){ case 1: printf("**********************\n"); printf("* 通 讯 录 链 表 建 立 *\n"); printf("***********************\n"); head=CreateList(); break; case 2: printf("*********************\n"); printf("通 讯 录 信 息 的 插 入 *\n"); printf("*********************\n"); printf("请输入编号,姓名,性别,电话和地址 \n"); printf("**********************************\n"); p=(ListNode*)malloc(sizeof(ListNode)); scanf("%s%s%s%s%s",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr); InsertNode(head,p); break; case 3: printf("***********************\n"); printf("通 讯 录 的 查 询 *\n"); p=ListFind(head); if(p!=NULL){ printf("编号 姓名 性别 电话 地址 \n"); printf("-------------------------- \n"); printf("%s%s%s%s%s",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr); } else printf("没查到要查询的通讯者!\n"); break; case 4: printf("***********************\n"); printf("* 通 讯 者 信 息 的 修 改 *\n"); printf("**********************\n"); ChangeNode(head); break; case 5: printf("************************\n"); printf("通 讯 录 的 信 息 删 除 *\n"); printf("*************************\n"); DelNode(head); break; case 6: printf("************************\n"); printf("通 讯 录 链 表 的 输 出 *\n"); printf("*************************\n"); printList(head); break; case 0: printf("\t 再 见!\n"); return 0; } } } int menu_select(){ int sn; printf(" 通讯录管理系统\n"); printf("========================\n"); printf(" 1. 通讯录链表的建立\n"); printf(" 2. 通讯录信息的插入\n"); printf(" 3. 通讯录信息的查询\n"); printf(" 4. 通讯录信息的修改\n"); printf(" 5. 通讯录信息的删除\n"); printf(" 6. 通讯录信息的输出\n"); printf(" 0. 退出管理系统\n"); printf(" 请 选 择 0—6:"); for(; ;){ scanf("%d",&sn); if(sn<0 || sn>6) printf("\n\t输入错误,重选0-6:"); else break; } return sn; } LinkList CreateList(void){ LinkList head=(ListNode *)malloc(sizeof(ListNode)); ListNode *p,*rear; char flag='y'; rear=head; while(flag=='y'){ p=(ListNode *)malloc(sizeof(ListNode)); printf("请顺序输入编号,姓名,性别,电话和地址\n"); printf("--------------------------------------\n"); scanf("%s%s%s%s%s",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr); rear->next=p; rear=p; printf("继续输入吗? (y/n):"); getchar(); scanf("%c",&flag); } rear->next=NULL; return head; } void InsertNode(LinkList head,ListNode *p){ ListNode *p1,*p2; p1=head; p2=p1->next; while(p2!=NULL && strcmp(p2->data.num,p->data.num)<0) { p1=p2; p2=p2->next; } p1->next=p; p->next=p2; } ListNode *ListFind(LinkList head){ ListNode *p; char num[5]; char name[9]; int xz=0; printf("===========\n"); printf("1. 按编号查询 \n"); printf("2. 按姓名查询 \n"); printf("===========\n"); printf(" 请选择:"); p=head->next; scanf("%d",&xz); if(xz==1){ printf("请输入要查询者的编号:"); scanf("%s",num); while(p && strcmp(p->data.num,num)<0) p=p->next; if(p==NULL||strcmp(p->data.num,num)>0) p=NULL; } else if(xz==2) { printf("请输入要查询者的姓名:"); scanf("%s",name); while(p && strcmp(p->data.name,name)!=0) p=p->next; } return p; } void DelNode(LinkList head){ char jx; ListNode *p,*q; p=ListFind(head); if(p==NULL){ printf("没有查到要删除的通讯者!\n"); return; } printf("真的要删除该节点吗?(y/n):"); getchar(); scanf("%c",&jx); if(jx=='y'||jx=='Y'){ q=head; while(q!=NULL && q->next!=p) q=q->next; q->next=p->next; free(p); printf("通讯录已经删除!\n"); } } void printList(LinkList head){ ListNode *p; p=head->next; printf("编号 姓名 性别 电话 地址\n"); printf("--------------------------------------\n"); while(p!=NULL) { printf("%s%s%s%s%s\n",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr); printf("--------------------------------\n"); p=p->next; } } void ChangeNode(LinkList head){ ListNode *p; p=ListFind(head); if(p!=NULL){ printf("编号 姓名 性别 电话 地址\n"); printf("--------------------------------------\n"); scanf("%s%s%s%s%s\n",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr); printf("--------------------------------------\n"); printf("输入该通讯录者正确的联系电话 通讯地址:\n中间用空格号分隔\n"); scanf("%s%s",p->data.phone,p->data.addr); } else printf("没查到要查询的通讯录者!\n"); }

更多学习资料请关注专题《管理系统开发》。

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

如何用C语言设计并实现高效的通讯管理系统?

本文共计1646个文字,预计阅读时间需要7分钟。

如何用C语言设计并实现高效的通讯管理系统?

本文实例展示了如何使用C语言实现通讯管理系统。以下为具体代码示例,供大家参考:

c#include #include

// 定义通讯录结构体typedef struct { char name[50]; char phone[20];} Contact;

// 函数声明void addContact(Contact *contacts, int *count);void deleteContact(Contact *contacts, int *count);void listContacts(const Contact *contacts, int count);void searchContact(const Contact *contacts, int count);

int main() { Contact contacts[100]; // 通讯录数组,最多存储100个联系人 int count=0; // 当前通讯录中联系人的数量

// 主循环,根据用户输入执行相应操作 while (1) { printf(1. 添加联系人\n); printf(2. 删除联系人\n); printf(3. 列出所有联系人\n); printf(4. 搜索联系人\n); printf(5. 退出\n); printf(请输入操作编号:); int choice; scanf(%d, &choice);

switch (choice) { case 1: addContact(contacts, &count); break; case 2: deleteContact(contacts, &count); break; case 3: listContacts(contacts, count); break; case 4: searchContact(contacts, count); break; case 5: return 0; default: printf(无效的操作编号,请重新输入。\n); } }

return 0;}

// 添加联系人函数void addContact(Contact *contacts, int *count) { if (*count >=100) { printf(通讯录已满,无法添加更多联系人。\n); return; }

printf(请输入联系人姓名:); scanf(%s, contacts[*count].name); printf(请输入联系人电话:); scanf(%s, contacts[*count].phone); (*count)++; printf(联系人添加成功!\n);}

// 删除联系人函数void deleteContact(Contact *contacts, int *count) { if (*count==0) { printf(通讯录为空,无法删除联系人。\n); return; }

char name[50]; printf(请输入要删除的联系人姓名:); scanf(%s, name);

for (int i=0; i < *count; i++) { if (strcmp(contacts[i].name, name)==0) { for (int j=i; j < *count - 1; j++) { contacts[j]=contacts[j + 1]; } (*count)--; printf(联系人删除成功!\n); return; } }

printf(未找到该联系人。\n);}

// 列出所有联系人函数void listContacts(const Contact *contacts, int count) { if (count==0) { printf(通讯录为空。\n); return; }

printf(通讯录如下:\n); for (int i=0; i

// 搜索联系人函数void searchContact(const Contact *contacts, int count) { if (count==0) { printf(通讯录为空。\n); return; }

char name[50]; printf(请输入要搜索的联系人姓名:); scanf(%s, name);

for (int i=0; i

printf(未找到该联系人。\n);}

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

#include<stdio.h> #include<string.h> #include<stdlib.h> typedef struct{ char num[5]; char name[9]; char sex[9]; char phone[13]; char addr[31]; }DataType; typedef struct node{ DataType data; struct node*next; } ListNode, *LinkList; LinkList head; ListNode *p; int menu_select(); LinkList CreateList(void); void InsertNode(LinkList head,ListNode *p); ListNode *ListFind(LinkList head); void DelNode(LinkList head); void printList(LinkList head); void ChangeNode(LinkList head); int main(void){ for(; ;){ switch(menu_select()){ case 1: printf("**********************\n"); printf("* 通 讯 录 链 表 建 立 *\n"); printf("***********************\n"); head=CreateList(); break; case 2: printf("*********************\n"); printf("通 讯 录 信 息 的 插 入 *\n"); printf("*********************\n"); printf("请输入编号,姓名,性别,电话和地址 \n"); printf("**********************************\n"); p=(ListNode*)malloc(sizeof(ListNode)); scanf("%s%s%s%s%s",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr); InsertNode(head,p); break; case 3: printf("***********************\n"); printf("通 讯 录 的 查 询 *\n"); p=ListFind(head); if(p!=NULL){ printf("编号 姓名 性别 电话 地址 \n"); printf("-------------------------- \n"); printf("%s%s%s%s%s",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr); } else printf("没查到要查询的通讯者!\n"); break; case 4: printf("***********************\n"); printf("* 通 讯 者 信 息 的 修 改 *\n"); printf("**********************\n"); ChangeNode(head); break; case 5: printf("************************\n"); printf("通 讯 录 的 信 息 删 除 *\n"); printf("*************************\n"); DelNode(head); break; case 6: printf("************************\n"); printf("通 讯 录 链 表 的 输 出 *\n"); printf("*************************\n"); printList(head); break; case 0: printf("\t 再 见!\n"); return 0; } } } int menu_select(){ int sn; printf(" 通讯录管理系统\n"); printf("========================\n"); printf(" 1. 通讯录链表的建立\n"); printf(" 2. 通讯录信息的插入\n"); printf(" 3. 通讯录信息的查询\n"); printf(" 4. 通讯录信息的修改\n"); printf(" 5. 通讯录信息的删除\n"); printf(" 6. 通讯录信息的输出\n"); printf(" 0. 退出管理系统\n"); printf(" 请 选 择 0—6:"); for(; ;){ scanf("%d",&sn); if(sn<0 || sn>6) printf("\n\t输入错误,重选0-6:"); else break; } return sn; } LinkList CreateList(void){ LinkList head=(ListNode *)malloc(sizeof(ListNode)); ListNode *p,*rear; char flag='y'; rear=head; while(flag=='y'){ p=(ListNode *)malloc(sizeof(ListNode)); printf("请顺序输入编号,姓名,性别,电话和地址\n"); printf("--------------------------------------\n"); scanf("%s%s%s%s%s",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr); rear->next=p; rear=p; printf("继续输入吗? (y/n):"); getchar(); scanf("%c",&flag); } rear->next=NULL; return head; } void InsertNode(LinkList head,ListNode *p){ ListNode *p1,*p2; p1=head; p2=p1->next; while(p2!=NULL && strcmp(p2->data.num,p->data.num)<0) { p1=p2; p2=p2->next; } p1->next=p; p->next=p2; } ListNode *ListFind(LinkList head){ ListNode *p; char num[5]; char name[9]; int xz=0; printf("===========\n"); printf("1. 按编号查询 \n"); printf("2. 按姓名查询 \n"); printf("===========\n"); printf(" 请选择:"); p=head->next; scanf("%d",&xz); if(xz==1){ printf("请输入要查询者的编号:"); scanf("%s",num); while(p && strcmp(p->data.num,num)<0) p=p->next; if(p==NULL||strcmp(p->data.num,num)>0) p=NULL; } else if(xz==2) { printf("请输入要查询者的姓名:"); scanf("%s",name); while(p && strcmp(p->data.name,name)!=0) p=p->next; } return p; } void DelNode(LinkList head){ char jx; ListNode *p,*q; p=ListFind(head); if(p==NULL){ printf("没有查到要删除的通讯者!\n"); return; } printf("真的要删除该节点吗?(y/n):"); getchar(); scanf("%c",&jx); if(jx=='y'||jx=='Y'){ q=head; while(q!=NULL && q->next!=p) q=q->next; q->next=p->next; free(p); printf("通讯录已经删除!\n"); } } void printList(LinkList head){ ListNode *p; p=head->next; printf("编号 姓名 性别 电话 地址\n"); printf("--------------------------------------\n"); while(p!=NULL) { printf("%s%s%s%s%s\n",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr); printf("--------------------------------\n"); p=p->next; } } void ChangeNode(LinkList head){ ListNode *p; p=ListFind(head); if(p!=NULL){ printf("编号 姓名 性别 电话 地址\n"); printf("--------------------------------------\n"); scanf("%s%s%s%s%s\n",p->data.num,p->data.name,p->data.sex,p->data.phone,p->data.addr); printf("--------------------------------------\n"); printf("输入该通讯录者正确的联系电话 通讯地址:\n中间用空格号分隔\n"); scanf("%s%s",p->data.phone,p->data.addr); } else printf("没查到要查询的通讯录者!\n"); }

更多学习资料请关注专题《管理系统开发》。

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

如何用C语言设计并实现高效的通讯管理系统?