如何用C语言编写电话簿管理系统?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1849个文字,预计阅读时间需要8分钟。
本例展示了如何用C语言实现电话薄项目的整体代码。供大家参考,内容如下:
实现思路:
1.该程序的整体思路很简单,我们首先定义一个结构体来存储电话薄中的信息,然后通过动态内存分配来创建电话薄的数组。
2.接着,我们实现增加、删除、查询和显示电话薄的功能。
3.最后,我们释放动态分配的内存。
代码实现:
c
#include #include #include// 定义电话薄信息结构体typedef struct { char name[50]; char phone[20];} PhoneBook;
// 动态分配内存并创建电话薄PhoneBook* createPhoneBook(int size) { PhoneBook* book=(PhoneBook*)malloc(size * sizeof(PhoneBook)); if (book==NULL) { printf(内存分配失败\n); exit(1); } return book;}
// 增加电话薄信息void addPhoneBook(PhoneBook* book, int* size, char* name, char* phone) { book[*size].name=strcpy(book[*size].name, name); book[*size].phone=strcpy(book[*size].phone, phone); (*size)++;}
// 删除电话薄信息void deletePhoneBook(PhoneBook* book, int* size, char* name) { for (int i=0; i < *size; i++) { if (strcmp(book[i].name, name)==0) { for (int j=i; j < *size - 1; j++) { book[j]=book[j + 1]; } (*size)--; break; } }}
// 查询电话薄信息void searchPhoneBook(PhoneBook* book, int size, char* name) { for (int i=0; i // 显示电话薄信息void displayPhoneBook(PhoneBook* book, int size) { for (int i=0; i int main() { int size=5; // 初始电话薄大小 PhoneBook* book=createPhoneBook(size); // 增加电话薄信息 addPhoneBook(book, &size, 张三, 123456789); addPhoneBook(book, &size, 李四, 987654321); // 显示电话薄信息 displayPhoneBook(book, size); // 查询电话薄信息 searchPhoneBook(book, size, 张三); // 删除电话薄信息 deletePhoneBook(book, &size, 张三); // 再次显示电话薄信息 displayPhoneBook(book, size); // 释放动态分配的内存 free(book); return 0;} 以上代码实现了电话薄的基本功能,包括增加、删除、查询和显示电话薄信息。通过动态内存分配,我们可以方便地扩展电话薄的大小。在实际应用中,可以根据需求进一步完善和优化程序。 本文实例为大家分享了C语言实现电话簿项目的具体代码,供大家参考,具体内容如下 实现思路 这个程序的整体思路和实现还是很简单的,我们利用了动态分配内存的方式首先创建了电话簿联系人类型,然后创建电话簿类,其实事联系人类型构成的全局数组,然后分别实现,界面函数,增删改查打印等功能,在主函数离实现总体思路,利用while循环让用户选择具体功能调用函数的方式进行总体实现。 ———————————————————————— 2019.3.12更新: 实现代码
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <string.h>
#define ADDRESS_INFOS_MAX 200
typedef struct AddressInfo
{
char name[1024];
char phone[1024];
}AddressInfo;
typedef struct AddressBook
{
AddressInfo* infos;
int size;
int capacity;//容量
}AddressBook;
AddressBook g_addr_book;
//初始化
void Init(AddressBook* addr_book)
{
assert(addr_book != NULL);
addr_book->size = 0;
addr_book->capacity = 10;
addr_book->infos = (AddressInfo*)malloc(sizeof(AddressInfo) * addr_book->capacity);
return;
}
//菜单
int Menu()
{
printf("===========================\n");
printf("1、新增\n");
printf("2、删除\n");
printf("3、修改\n");
printf("4、查找\n");
printf("5、排序\n");
printf("6、显示全部\n");
printf("7、删除全部\n");
printf("0、退出\n");
printf("===========================\n");
int choice;
scanf("%d", &choice);
return choice;
}
//扩容
void Realloc(AddressBook* addr_book)
{
assert(addr_book != NULL);
//1、扩大capacity的取值
addr_book->capacity *= 2;
//2、申请一个更大的内存
AddressInfo* old_infos = addr_book->infos;
addr_book->infos = (AddressInfo*)malloc(sizeof(AddressInfo) * addr_book->capacity);
//3、将原有内存中的数据复制过来
for(int i = 0; i < addr_book->size; i++)
{
addr_book->infos[i] = old_infos[i];
}
//4、释放原有的内存
free(old_infos);
//此处每次扩容阔多少由我们自己定制
printf("扩容成功!\n");
}
//新增
void AddAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
if(addr_book->size >= addr_book->capacity)
{
printf("空间已满进行扩容!\n");
Realloc(addr_book);//扩容
}
printf("请输入联系人信息!\n");
AddressInfo* p = &addr_book->infos[addr_book->size];
printf("请输入联系人姓名:");
scanf("%s", p->name);
printf("请输入联系人电话:");
scanf("%s", p->phone);
addr_book->size++;
printf("添加成功!\n");
return;
}
//删除
void DelAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
int id;
printf("请输入要删除的联系人序号:");
scanf("%d", &id);
if(id < 0 || id >= addr_book->size)
{
printf("输入需要有误!\n");
return;
}
printf("删除的序号为[%d],确认删除请输入Y:", id);
char sure[1024] = {0};
scanf("%s", sure);
if(strcmp(sure, "Y") != 0)
{
printf("删除中止!\n");
return;
}
AddressInfo* from = &addr_book->infos[addr_book->size - 1];
AddressInfo* to = &addr_book->infos[0];
*to = *from;
addr_book->size--;
return;
}
//修改
void ModifyAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
printf("修改联系人!\n");
printf("请输入需要修改的联系人序号:");
int id = 0;
scanf("%d", &id);
if(id < 0 || id >= addr_book->size)
{
printf("输入序号错误!\n");
return;
}
AddressInfo* p = &addr_book->infos[id];
char input[1024] = {0};
printf("请输入要修改的姓名:");
scanf("%s", input);
if(strcmp(input, "#") != 0)
{
strcpy(p->name, input);
}
printf("请输入要修改的电话:");
scanf("%s", input);
if(strcmp(input, "#") != 0)
{
strcpy(p->phone, input);
}
printf("修改成功!\n");
return;
}
//查找
void FindAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
printf("开始进行查找!\n");
printf("请输入要查找的姓名:");
char name[1024] = {0};
scanf("%s", name);
int count = 0;
for(int i = 0; i < addr_book->size; i++)
{
AddressInfo* p = &addr_book->infos[i];
if(strcmp(name, p->name) == 0)
{
printf("[%d] %s\t %s", i, p->name, p->phone);
++count;
}
}
return;
}
//排序
void SortAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
for(int i = 0; i < addr_book->size - 1; i++)//冒泡排序
{
for(int j = 0; j < addr_book->size - i - 1; j++)
{
if(strcmp(addr_book->infos[j].name, addr_book->infos[j + 1].name) > 0)
{
AddressInfo temp = addr_book->infos[j];
addr_book->infos[j] = addr_book->infos[j + 1];
addr_book->infos[j + 1] = temp;
}
}
}
printf("排序完成!\n");
}
//打印全部
void PrintAllAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
printf("显示所有联系人!\n");
for(int i = 0; i < addr_book->size; i++)
{
AddressInfo* p = &addr_book->infos[i];
printf("[%d] %s\t%s\n", i, p->name, p->phone);
}
printf("共显示了%d条数据!\n", addr_book->size);
return;
}
//清除全部
void ClearAllAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
printf("确定要清除全部信息么,确定请输入Y:");
char sure[1024] = {0};
scanf("%s", sure);
if(strcmp(sure, "Y") != 0)
{
printf("清除已经取消!\n");
return;
}
addr_book->size = 0;
return;
}
//文件读取
size_t Read(AddressBook* addr_book)
{
FILE* fp = fopen("./AddrBookData.txt", "r");
if(fp == NULL)
{
fp = fopen("./AddrBookData.txt", "w+");
}
size_t n = 0;
char* buf[1024] = { 0 };
while(fgets(buf, sizeof(buf), fp) != NULL)
{
if(addr_book->size >= addr_book->capacity)
{
Realloc(addr_book);//扩容
}
AddressInfo* p = &addr_book->infos[addr_book->size];
sscanf(buf, "%s %s", p->name, p->phone);
addr_book->size++;
}
fclose(fp);
n = addr_book->size;
printf("读取了%lu条数据!\n", n);
return n;
}
//文件存储
size_t Save(AddressBook* addr_book)
{
FILE* fp = fopen("./AddrBookData.txt", "w");
size_t n = 0;
for(int i = 0; i < addr_book->size; i++)
{
fprintf(fp, "%s %s\n", addr_book->infos[i].name, addr_book->infos[i].phone);
n++;
}
fclose(fp);
printf("存储了%lu条数据!\n", n);
return n;
}
int main()
{
Init(&g_addr_book);
Read(&g_addr_book);
typedef void (*ptr_func)(AddressBook*);
ptr_func table[] = {
AddAddressBook,
DelAddressBook,
ModifyAddressBook,
FindAddressBook,
SortAddressBook,
PrintAllAddressBook,
ClearAllAddressBook,
};
while(1)
{
int choice = Menu();
if(choice == 0)
{
printf("使用完毕,退出!\n");
Save(&g_addr_book);
return 0;
}
table[choice - 1](&g_addr_book);
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。
利用文件操作使得系统可以进行数据的保存。
本文共计1849个文字,预计阅读时间需要8分钟。
本例展示了如何用C语言实现电话薄项目的整体代码。供大家参考,内容如下:
实现思路:
1.该程序的整体思路很简单,我们首先定义一个结构体来存储电话薄中的信息,然后通过动态内存分配来创建电话薄的数组。
2.接着,我们实现增加、删除、查询和显示电话薄的功能。
3.最后,我们释放动态分配的内存。
代码实现:
c
#include #include #include// 定义电话薄信息结构体typedef struct { char name[50]; char phone[20];} PhoneBook;
// 动态分配内存并创建电话薄PhoneBook* createPhoneBook(int size) { PhoneBook* book=(PhoneBook*)malloc(size * sizeof(PhoneBook)); if (book==NULL) { printf(内存分配失败\n); exit(1); } return book;}
// 增加电话薄信息void addPhoneBook(PhoneBook* book, int* size, char* name, char* phone) { book[*size].name=strcpy(book[*size].name, name); book[*size].phone=strcpy(book[*size].phone, phone); (*size)++;}
// 删除电话薄信息void deletePhoneBook(PhoneBook* book, int* size, char* name) { for (int i=0; i < *size; i++) { if (strcmp(book[i].name, name)==0) { for (int j=i; j < *size - 1; j++) { book[j]=book[j + 1]; } (*size)--; break; } }}
// 查询电话薄信息void searchPhoneBook(PhoneBook* book, int size, char* name) { for (int i=0; i // 显示电话薄信息void displayPhoneBook(PhoneBook* book, int size) { for (int i=0; i int main() { int size=5; // 初始电话薄大小 PhoneBook* book=createPhoneBook(size); // 增加电话薄信息 addPhoneBook(book, &size, 张三, 123456789); addPhoneBook(book, &size, 李四, 987654321); // 显示电话薄信息 displayPhoneBook(book, size); // 查询电话薄信息 searchPhoneBook(book, size, 张三); // 删除电话薄信息 deletePhoneBook(book, &size, 张三); // 再次显示电话薄信息 displayPhoneBook(book, size); // 释放动态分配的内存 free(book); return 0;} 以上代码实现了电话薄的基本功能,包括增加、删除、查询和显示电话薄信息。通过动态内存分配,我们可以方便地扩展电话薄的大小。在实际应用中,可以根据需求进一步完善和优化程序。 本文实例为大家分享了C语言实现电话簿项目的具体代码,供大家参考,具体内容如下 实现思路 这个程序的整体思路和实现还是很简单的,我们利用了动态分配内存的方式首先创建了电话簿联系人类型,然后创建电话簿类,其实事联系人类型构成的全局数组,然后分别实现,界面函数,增删改查打印等功能,在主函数离实现总体思路,利用while循环让用户选择具体功能调用函数的方式进行总体实现。 ———————————————————————— 2019.3.12更新: 实现代码
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <string.h>
#define ADDRESS_INFOS_MAX 200
typedef struct AddressInfo
{
char name[1024];
char phone[1024];
}AddressInfo;
typedef struct AddressBook
{
AddressInfo* infos;
int size;
int capacity;//容量
}AddressBook;
AddressBook g_addr_book;
//初始化
void Init(AddressBook* addr_book)
{
assert(addr_book != NULL);
addr_book->size = 0;
addr_book->capacity = 10;
addr_book->infos = (AddressInfo*)malloc(sizeof(AddressInfo) * addr_book->capacity);
return;
}
//菜单
int Menu()
{
printf("===========================\n");
printf("1、新增\n");
printf("2、删除\n");
printf("3、修改\n");
printf("4、查找\n");
printf("5、排序\n");
printf("6、显示全部\n");
printf("7、删除全部\n");
printf("0、退出\n");
printf("===========================\n");
int choice;
scanf("%d", &choice);
return choice;
}
//扩容
void Realloc(AddressBook* addr_book)
{
assert(addr_book != NULL);
//1、扩大capacity的取值
addr_book->capacity *= 2;
//2、申请一个更大的内存
AddressInfo* old_infos = addr_book->infos;
addr_book->infos = (AddressInfo*)malloc(sizeof(AddressInfo) * addr_book->capacity);
//3、将原有内存中的数据复制过来
for(int i = 0; i < addr_book->size; i++)
{
addr_book->infos[i] = old_infos[i];
}
//4、释放原有的内存
free(old_infos);
//此处每次扩容阔多少由我们自己定制
printf("扩容成功!\n");
}
//新增
void AddAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
if(addr_book->size >= addr_book->capacity)
{
printf("空间已满进行扩容!\n");
Realloc(addr_book);//扩容
}
printf("请输入联系人信息!\n");
AddressInfo* p = &addr_book->infos[addr_book->size];
printf("请输入联系人姓名:");
scanf("%s", p->name);
printf("请输入联系人电话:");
scanf("%s", p->phone);
addr_book->size++;
printf("添加成功!\n");
return;
}
//删除
void DelAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
int id;
printf("请输入要删除的联系人序号:");
scanf("%d", &id);
if(id < 0 || id >= addr_book->size)
{
printf("输入需要有误!\n");
return;
}
printf("删除的序号为[%d],确认删除请输入Y:", id);
char sure[1024] = {0};
scanf("%s", sure);
if(strcmp(sure, "Y") != 0)
{
printf("删除中止!\n");
return;
}
AddressInfo* from = &addr_book->infos[addr_book->size - 1];
AddressInfo* to = &addr_book->infos[0];
*to = *from;
addr_book->size--;
return;
}
//修改
void ModifyAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
printf("修改联系人!\n");
printf("请输入需要修改的联系人序号:");
int id = 0;
scanf("%d", &id);
if(id < 0 || id >= addr_book->size)
{
printf("输入序号错误!\n");
return;
}
AddressInfo* p = &addr_book->infos[id];
char input[1024] = {0};
printf("请输入要修改的姓名:");
scanf("%s", input);
if(strcmp(input, "#") != 0)
{
strcpy(p->name, input);
}
printf("请输入要修改的电话:");
scanf("%s", input);
if(strcmp(input, "#") != 0)
{
strcpy(p->phone, input);
}
printf("修改成功!\n");
return;
}
//查找
void FindAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
printf("开始进行查找!\n");
printf("请输入要查找的姓名:");
char name[1024] = {0};
scanf("%s", name);
int count = 0;
for(int i = 0; i < addr_book->size; i++)
{
AddressInfo* p = &addr_book->infos[i];
if(strcmp(name, p->name) == 0)
{
printf("[%d] %s\t %s", i, p->name, p->phone);
++count;
}
}
return;
}
//排序
void SortAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
for(int i = 0; i < addr_book->size - 1; i++)//冒泡排序
{
for(int j = 0; j < addr_book->size - i - 1; j++)
{
if(strcmp(addr_book->infos[j].name, addr_book->infos[j + 1].name) > 0)
{
AddressInfo temp = addr_book->infos[j];
addr_book->infos[j] = addr_book->infos[j + 1];
addr_book->infos[j + 1] = temp;
}
}
}
printf("排序完成!\n");
}
//打印全部
void PrintAllAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
printf("显示所有联系人!\n");
for(int i = 0; i < addr_book->size; i++)
{
AddressInfo* p = &addr_book->infos[i];
printf("[%d] %s\t%s\n", i, p->name, p->phone);
}
printf("共显示了%d条数据!\n", addr_book->size);
return;
}
//清除全部
void ClearAllAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
printf("确定要清除全部信息么,确定请输入Y:");
char sure[1024] = {0};
scanf("%s", sure);
if(strcmp(sure, "Y") != 0)
{
printf("清除已经取消!\n");
return;
}
addr_book->size = 0;
return;
}
//文件读取
size_t Read(AddressBook* addr_book)
{
FILE* fp = fopen("./AddrBookData.txt", "r");
if(fp == NULL)
{
fp = fopen("./AddrBookData.txt", "w+");
}
size_t n = 0;
char* buf[1024] = { 0 };
while(fgets(buf, sizeof(buf), fp) != NULL)
{
if(addr_book->size >= addr_book->capacity)
{
Realloc(addr_book);//扩容
}
AddressInfo* p = &addr_book->infos[addr_book->size];
sscanf(buf, "%s %s", p->name, p->phone);
addr_book->size++;
}
fclose(fp);
n = addr_book->size;
printf("读取了%lu条数据!\n", n);
return n;
}
//文件存储
size_t Save(AddressBook* addr_book)
{
FILE* fp = fopen("./AddrBookData.txt", "w");
size_t n = 0;
for(int i = 0; i < addr_book->size; i++)
{
fprintf(fp, "%s %s\n", addr_book->infos[i].name, addr_book->infos[i].phone);
n++;
}
fclose(fp);
printf("存储了%lu条数据!\n", n);
return n;
}
int main()
{
Init(&g_addr_book);
Read(&g_addr_book);
typedef void (*ptr_func)(AddressBook*);
ptr_func table[] = {
AddAddressBook,
DelAddressBook,
ModifyAddressBook,
FindAddressBook,
SortAddressBook,
PrintAllAddressBook,
ClearAllAddressBook,
};
while(1)
{
int choice = Menu();
if(choice == 0)
{
printf("使用完毕,退出!\n");
Save(&g_addr_book);
return 0;
}
table[choice - 1](&g_addr_book);
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。
利用文件操作使得系统可以进行数据的保存。

