用c语言编写通讯录的九个功能
时间: 2023-10-25 11:08:03 浏览: 107
好的,下面是用C语言编写通讯录的九个功能:
1. 添加联系人:向通讯录中添加新的联系人,包括姓名、电话号码、电子邮件等信息。
2. 显示联系人:显示通讯录中所有联系人的信息。
3. 查找联系人:根据姓名查找通讯录中的联系人信息。
4. 删除联系人:根据姓名删除通讯录中的联系人信息。
5. 修改联系人:根据姓名修改通讯录中的联系人信息。
6. 排序联系人:按照姓名或电话号码等信息对通讯录中的联系人进行排序。
7. 导出联系人:将通讯录中的联系人信息导出到文件中。
8. 导入联系人:从文件中导入联系人信息到通讯录中。
9. 清空联系人:清空通讯录中的所有联系人信息。
以上就是用C语言编写通讯录的九个功能,希望能对你有所帮助。
相关问题
c语言编写通讯录管理系统
好的,通讯录管理系统是一个非常实用的小型应用程序,主要用于管理联系人信息。下面是一个简单的C语言程序,可以实现通讯录管理系统的基本功能:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_CONTACTS 100
typedef struct {
char name[20];
char phone[20];
} Contact;
Contact contacts[MAX_CONTACTS];
int numContacts = 0;
void printMenu() {
printf("\n\n1. 添加联系人\n");
printf("2. 显示所有联系人\n");
printf("3. 查找联系人\n");
printf("4. 删除联系人\n");
printf("5. 退出程序\n\n");
printf("请选择操作:");
}
void addContact() {
Contact newContact;
printf("请输入联系人姓名:");
scanf("%s", newContact.name);
printf("请输入联系人电话:");
scanf("%s", newContact.phone);
contacts[numContacts] = newContact;
numContacts++;
printf("联系人添加成功!\n");
}
void printContacts() {
printf("\n所有联系人:\n");
for (int i = 0; i < numContacts; i++) {
printf("%s\t\t%s\n", contacts[i].name, contacts[i].phone);
}
}
void searchContact() {
char name[20];
printf("请输入要查找的联系人姓名:");
scanf("%s", name);
for (int i = 0; i < numContacts; i++) {
if (strcmp(name, contacts[i].name) == 0) {
printf("%s\t\t%s\n", contacts[i].name, contacts[i].phone);
return;
}
}
printf("未找到该联系人!\n");
}
void deleteContact() {
char name[20];
printf("请输入要删除的联系人姓名:");
scanf("%s", name);
for (int i = 0; i < numContacts; i++) {
if (strcmp(name, contacts[i].name) == 0) {
for (int j = i; j < numContacts - 1; j++) {
contacts[j] = contacts[j+1];
}
numContacts--;
printf("联系人删除成功!\n");
return;
}
}
printf("未找到该联系人!\n");
}
int main() {
int choice;
while (1) {
printMenu();
scanf("%d", &choice);
switch (choice) {
case 1:
addContact();
break;
case 2:
printContacts();
break;
case 3:
searchContact();
break;
case 4:
deleteContact();
break;
case 5:
printf("程序已退出!\n");
exit(0);
default:
printf("请输入正确的操作!\n");
}
}
return 0;
}
```
这个程序使用了结构体来存储联系人的姓名和电话,使用了一个全局变量`numContacts`来记录当前通讯录中联系人的数量。程序提供了五个选项,具体功能如下:
1. 添加联系人:让用户输入联系人的姓名和电话,将其添加到通讯录中;
2. 显示所有联系人:遍历通讯录中的所有联系人,将其姓名和电话打印出来;
3. 查找联系人:让用户输入要查找的联系人姓名,从通讯录中查找该联系人并打印出来;
4. 删除联系人:让用户输入要删除的联系人姓名,从通讯录中删除该联系人;
5. 退出程序:结束程序运行。
这个程序只是一个简单的示例,如果你想要实现更多的功能,可以在此基础上进行扩展。
用C语言编写通讯录系统代码,并采用数据结构知识
以下是一个基于链表数据结构的通讯录系统的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;
}
```
以上代码实现了基本的添加、删除、修改、查找和显示所有联系人的功能。通过使用链表数据结构,可以方便地实现对联系人的添加、删除和修改等操作。
阅读全文