用C语言编写通讯录系统代码,并采用数据结构知识
时间: 2024-03-11 18:49:01 浏览: 64
以下是一个基于链表数据结构的通讯录系统的C语言代码示例:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 联系人信息结构体
typedef struct {
char name[20]; // 姓名
char phone[20]; // 电话号码
char address[50]; // 地址
} Contact;
// 链表节点结构体
typedef struct Node {
Contact contact; // 联系人信息
struct Node *next; // 指向下一个节点的指针
} Node;
// 头节点指针
Node *head = NULL;
// 添加联系人
void addContact() {
Contact newContact;
printf("请输入联系人姓名:");
scanf("%s", newContact.name);
printf("请输入联系人电话号码:");
scanf("%s", newContact.phone);
printf("请输入联系人地址:");
scanf("%s", newContact.address);
Node *newNode = (Node *)malloc(sizeof(Node));
newNode->contact = newContact;
newNode->next = NULL;
if (head == NULL) {
head = newNode;
} else {
Node *p = head;
while (p->next != NULL) {
p = p->next;
}
p->next = newNode;
}
printf("添加联系人成功!\n");
}
// 删除联系人
void deleteContact() {
char name[20];
printf("请输入要删除的联系人姓名:");
scanf("%s", name);
Node *p = head;
Node *prev = NULL;
while (p != NULL) {
if (strcmp(p->contact.name, name) == 0) {
if (prev == NULL) {
head = p->next;
} else {
prev->next = p->next;
}
free(p);
printf("删除联系人成功!\n");
return;
}
prev = p;
p = p->next;
}
printf("未找到该联系人!\n");
}
// 修改联系人
void modifyContact() {
char name[20];
printf("请输入要修改的联系人姓名:");
scanf("%s", name);
Node *p = head;
while (p != NULL) {
if (strcmp(p->contact.name, name) == 0) {
printf("请输入新的电话号码:");
scanf("%s", p->contact.phone);
printf("请输入新的地址:");
scanf("%s", p->contact.address);
printf("修改联系人成功!\n");
return;
}
p = p->next;
}
printf("未找到该联系人!\n");
}
// 查找联系人
void searchContact() {
char name[20];
printf("请输入要查找的联系人姓名:");
scanf("%s", name);
Node *p = head;
while (p != NULL) {
if (strcmp(p->contact.name, name) == 0) {
printf("姓名:%s\n电话:%s\n地址:%s\n", p->contact.name,
p->contact.phone, p->contact.address);
return;
}
p = p->next;
}
printf("未找到该联系人!\n");
}
// 显示所有联系人
void displayContacts() {
if (head == NULL) {
printf("通讯录为空!\n");
} else {
printf("所有联系人信息如下:\n");
Node *p = head;
while (p != NULL) {
printf("姓名:%s\n电话:%s\n地址:%s\n", p->contact.name,
p->contact.phone, p->contact.address);
p = p->next;
}
}
}
// 主函数
int main() {
int choice;
while (1) {
printf("请选择要进行的操作:\n");
printf("1. 添加联系人\n2. 删除联系人\n3. 修改联系人\n4. 查找联系人\n");
printf("5. 显示所有联系人\n6. 退出程序\n");
scanf("%d", &choice);
switch (choice) {
case 1:
addContact();
break;
case 2:
deleteContact();
break;
case 3:
modifyContact();
break;
case 4:
searchContact();
break;
case 5:
displayContacts();
break;
case 6:
return 0;
default:
printf("无效的选择!\n");
}
}
return 0;
}
```
以上代码实现了基本的添加、删除、修改、查找和显示所有联系人的功能。通过使用链表数据结构,可以方便地实现对联系人的添加、删除和修改等操作。
阅读全文