通讯录管理系统c语言数据结构
时间: 2023-11-29 21:06:44 浏览: 56
通讯录管理系统是一个基于C语言数据结构的应用程序,它主要用于管理通讯录信息。在这个系统中,使用了顺序表这种数据结构来存储通讯录信息。顺序表是一种线性表,它的元素在内存中是连续存储的,可以通过下标来访问元素。在这个系统中,使用了InitList()模块来定义顺序表,Create()模块来创建顺序表,Add()模块来添加通讯录信息,Find()模块来查找通讯录信息,Alter()模块来修改通讯录信息,Delete()模块来删除通讯录信息,List()模块来列出通讯录信息等等。此外,这个系统还使用了自定义的数据结构和内存量来方便各大模块的遍历。通过这个系统的设计和实现,可以训练学生灵活应用所学数据结构知识,独立完成问题分析,结合数据结构理论知识,编写程序求解指定问题。
相关问题
通讯录管理系统 c语言数据结构
通讯录管理系统是一种常见的应用程序,用于存储和管理联系人信息。在C语言中,可以使用顺序存储结构来实现通讯录管理系统。下面是一个简单的示例代码,演示了如何建立通讯录、插入联系人信息、删除联系人信息、查找联系人信息和显示联系人信息。
```c
#include <stdio.h>
#include <string.h>
#define MAX 100
typedef struct {
char name[9];
char tel[12];
} Address;
typedef Address ElemType;
typedef struct {
ElemType data[MAX];
int len;
} AddressList;
void menu() {
printf("--欢迎来到学生通讯录管理系统--\n");
printf(" 1.建立通讯录 \n");
printf(" 2.插入联系人信息\n");
printf(" 3.删除联系人信息\n");
printf(" 4.查找联系人信息\n");
printf(" 5.显示联系人信息\n");
printf(" 6.退出系统管理 \n");
printf("--\n");
}
void createAddressList(AddressList *list) {
list->len = 0;
printf("请输入联系人姓名:");
scanf("%s", list->data[list->len].name);
printf("请输入联系人电话:");
scanf("%s", list->data[list->len].tel);
list->len++;
printf("通讯录建立成功!\n");
}
void insertContact(AddressList *list) {
if (list->len >= MAX) {
printf("通讯录已满,无法插入联系人信息!\n");
return;
}
printf("请输入联系人姓名:");
scanf("%s", list->data[list->len].name);
printf("请输入联系人电话:");
scanf("%s", list->data[list->len].tel);
list->len++;
printf("联系人信息插入成功!\n");
}
void deleteContact(AddressList *list) {
char name[9];
printf("请输入要删除的联系人姓名:");
scanf("%s", name);
int i;
for (i = 0; i < list->len; i++) {
if (strcmp(list->data[i].name, name) == 0) {
break;
}
}
if (i == list->len) {
printf("未找到该联系人信息!\n");
return;
}
for (; i < list->len - 1; i++) {
strcpy(list->data[i].name, list->data[i + 1].name);
strcpy(list->data[i].tel, list->data[i + 1].tel);
}
list->len--;
printf("联系人信息删除成功!\n");
}
void searchContact(AddressList *list) {
char name[9];
printf("请输入要查找的联系人姓名:");
scanf("%s", name);
int i;
for (i = 0; i < list->len; i++) {
if (strcmp(list->data[i].name, name) == 0) {
printf("联系人姓名:%s\n", list->data[i].name);
printf("联系人电话:%s\n", list->data[i].tel);
return;
}
}
printf("未找到该联系人信息!\n");
}
void displayContact(AddressList *list) {
if (list->len == 0) {
printf("通讯录为空!\n");
return;
}
printf("通讯录中的联系人信息如下:\n");
for (int i = 0; i < list->len; i++) {
printf("联系人姓名:%s\n", list->data[i].name);
printf("联系人电话:%s\n", list->data[i].tel);
}
}
int main() {
AddressList list;
int choice;
while (1) {
menu();
printf("请输入您的选择:");
scanf("%d", &choice);
switch (choice) {
case 1:
createAddressList(&list);
break;
case 2:
insertContact(&list);
break;
case 3:
deleteContact(&list);
break;
case 4:
searchContact(&list);
break;
case 5:
displayContact(&list);
break;
case 6:
printf("感谢使用学生通讯录管理系统,再见!\n");
return 0;
default:
printf("输入有误,请重新输入!\n");
break;
}
}
}
```
通讯录管理系统 数据结构c语言
以下是一个基于链表数据结构的通讯录管理系统的C语言实现,包括增加、删除、修改、查找和显示全部信息等功能:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 定义通讯录结构体
typedef struct AddressBook {
char name[20]; // 姓名
char phone[12]; // 电话号码
struct AddressBook *next; // 指向下一个节点的指针
} AddressBook;
// 添加联系人
void add(AddressBook **head) {
AddressBook *p = (AddressBook *)malloc(sizeof(AddressBook));
printf("请输入姓名:");
scanf("%s", p->name);
printf("请输入电话号码:");
scanf("%s", p->phone);
p->next = *head;
*head = p;
printf("添加成功!\n");
}
// 删除联系人
void del(AddressBook **head) {
char name[20];
printf("请输入要删除的联系人姓名:");
scanf("%s", name);
AddressBook *p = *head;
AddressBook *pre = NULL;
while (p != NULL) {
if (strcmp(p->name, name) == 0) {
if (pre == NULL) {
*head = p->next;
} else {
pre->next = p->next;
}
free(p);
printf("删除成功!\n");
return;
}
pre = p;
p = p->next;
}
printf("未找到该联系人!\n");
}
// 修改联系人
void modify(AddressBook *head) {
char name[20];
printf("请输入要修改的联系人姓名:");
scanf("%s", name);
AddressBook *p = head;
while (p != NULL) {
if (strcmp(p->name, name) == 0) {
printf("请输入新的电话号码:");
scanf("%s", p->phone);
printf("修改成功!\n");
return;
}
p = p->next;
}
printf("未找到该联系人!\n");
}
// 查找联系人
void search(AddressBook *head) {
char name[20];
printf("请输入要查找的联系人姓名:");
scanf("%s", name);
AddressBook *p = head;
while (p != NULL) {
if (strcmp(p->name, name) == 0) {
printf("姓名:%s,电话号码:%s\n", p->name, p->phone);
return;
}
p = p->next;
}
printf("未找到该联系人!\n");
}
// 显示全部联系人
void show(AddressBook *head) {
AddressBook *p = head;
while (p != NULL) {
printf("姓名:%s,电话号码:%s\n", p->name, p->phone);
p = p->next;
}
}
int main() {
AddressBook *head = NULL;
int choice;
while (1) {
printf("请选择操作:\n");
printf("1.添加联系人\n");
printf("2.删除联系人\n");
printf("3.修改联系人\n");
printf("4.查找联系人\n");
printf("5.显示全部联系人\n");
printf("6.退出\n");
scanf("%d", &choice);
switch (choice) {
case 1:
add(&head);
break;
case 2:
del(&head);
break;
case 3:
modify(head);
break;
case 4:
search(head);
break;
case 5:
show(head);
break;
case 6:
printf("谢谢使用!\n");
return 0;
default:
printf("输入有误,请重新输入!\n");
break;
}
}
return 0;
}
```
相关推荐
![doc](https://img-home.csdnimg.cn/images/20210720083327.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)