C語言實(shí)現(xiàn)電話簿項(xiàng)目
本文實(shí)例為大家分享了C語言實(shí)現(xiàn)電話簿項(xiàng)目的具體代碼,供大家參考,具體內(nèi)容如下
實(shí)現(xiàn)思路
這個(gè)程序的整體思路和實(shí)現(xiàn)還是很簡(jiǎn)單的,我們利用了動(dòng)態(tài)分配內(nèi)存的方式首先創(chuàng)建了電話簿聯(lián)系人類型,然后創(chuàng)建電話簿類,其實(shí)事聯(lián)系人類型構(gòu)成的全局?jǐn)?shù)組,然后分別實(shí)現(xiàn),界面函數(shù),增刪改查打印等功能,在主函數(shù)離實(shí)現(xiàn)總體思路,利用while循環(huán)讓用戶選擇具體功能調(diào)用函數(shù)的方式進(jìn)行總體實(shí)現(xiàn)。
————————————————————————
2019.3.12更新:
利用文件操作使得系統(tǒng)可以進(jìn)行數(shù)據(jù)的保存。
實(shí)現(xiàn)代碼
#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;
}
//擴(kuò)容
void Realloc(AddressBook* addr_book)
{
assert(addr_book != NULL);
//1、擴(kuò)大capacity的取值
addr_book->capacity *= 2;
//2、申請(qǐng)一個(gè)更大的內(nèi)存
AddressInfo* old_infos = addr_book->infos;
addr_book->infos = (AddressInfo*)malloc(sizeof(AddressInfo) * addr_book->capacity);
//3、將原有內(nèi)存中的數(shù)據(jù)復(fù)制過來
for(int i = 0; i < addr_book->size; i++)
{
addr_book->infos[i] = old_infos[i];
}
//4、釋放原有的內(nèi)存
free(old_infos);
//此處每次擴(kuò)容闊多少由我們自己定制
printf("擴(kuò)容成功!\n");
}
//新增
void AddAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
if(addr_book->size >= addr_book->capacity)
{
printf("空間已滿進(jìn)行擴(kuò)容!\n");
Realloc(addr_book);//擴(kuò)容
}
printf("請(qǐng)輸入聯(lián)系人信息!\n");
AddressInfo* p = &addr_book->infos[addr_book->size];
printf("請(qǐng)輸入聯(lián)系人姓名:");
scanf("%s", p->name);
printf("請(qǐng)輸入聯(lián)系人電話:");
scanf("%s", p->phone);
addr_book->size++;
printf("添加成功!\n");
return;
}
//刪除
void DelAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
int id;
printf("請(qǐng)輸入要?jiǎng)h除的聯(lián)系人序號(hào):");
scanf("%d", &id);
if(id < 0 || id >= addr_book->size)
{
printf("輸入需要有誤!\n");
return;
}
printf("刪除的序號(hào)為[%d],確認(rèn)刪除請(qǐng)輸入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("修改聯(lián)系人!\n");
printf("請(qǐng)輸入需要修改的聯(lián)系人序號(hào):");
int id = 0;
scanf("%d", &id);
if(id < 0 || id >= addr_book->size)
{
printf("輸入序號(hào)錯(cuò)誤!\n");
return;
}
AddressInfo* p = &addr_book->infos[id];
char input[1024] = {0};
printf("請(qǐng)輸入要修改的姓名:");
scanf("%s", input);
if(strcmp(input, "#") != 0)
{
strcpy(p->name, input);
}
printf("請(qǐng)輸入要修改的電話:");
scanf("%s", input);
if(strcmp(input, "#") != 0)
{
strcpy(p->phone, input);
}
printf("修改成功!\n");
return;
}
//查找
void FindAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
printf("開始進(jìn)行查找!\n");
printf("請(qǐng)輸入要查找的姓名:");
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("顯示所有聯(lián)系人!\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條數(shù)據(jù)!\n", addr_book->size);
return;
}
//清除全部
void ClearAllAddressBook(AddressBook* addr_book)
{
assert(addr_book != NULL);
printf("確定要清除全部信息么,確定請(qǐng)輸入Y:");
char sure[1024] = {0};
scanf("%s", sure);
if(strcmp(sure, "Y") != 0)
{
printf("清除已經(jīng)取消!\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);//擴(kuò)容
}
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條數(shù)據(jù)!\n", n);
return n;
}
//文件存儲(chǔ)
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("存儲(chǔ)了%lu條數(shù)據(jù)!\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);
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
windows下在vim中搭建c語言開發(fā)環(huán)境的詳細(xì)過程
這篇文章主要介紹了windows下在vim中搭建c語言開發(fā)環(huán)境,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-05-05
C語言使用結(jié)構(gòu)體實(shí)現(xiàn)簡(jiǎn)單通訊錄
這篇文章主要為大家詳細(xì)介紹了C語言使用結(jié)構(gòu)體實(shí)現(xiàn)簡(jiǎn)單通訊錄,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02
C++ 手把手教你實(shí)現(xiàn)可變長(zhǎng)的數(shù)組實(shí)現(xiàn)
這篇文章主要介紹了C++ 手把手教你實(shí)現(xiàn)可變長(zhǎng)的數(shù)組實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
C++實(shí)現(xiàn)約瑟夫環(huán)的循環(huán)單鏈表
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)約瑟夫環(huán)的循環(huán)單鏈表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10
C++?Qt開發(fā)之關(guān)聯(lián)容器類使用方法詳解
當(dāng)我們談?wù)摼幊讨械臄?shù)據(jù)結(jié)構(gòu)時(shí),順序容器是不可忽視的一個(gè)重要概念,Qt?中提供了豐富的容器類,用于方便地管理和操作數(shù)據(jù),本章我們將主要學(xué)習(xí)關(guān)聯(lián)容器,主要包括?QMap?,QSet和?QHash,感興趣的朋友跟著小編一起來學(xué)習(xí)吧2023-12-12
詳解C++中String類模擬實(shí)現(xiàn)以及深拷貝淺拷貝
這篇文章主要介紹了詳解C++中String類模擬實(shí)現(xiàn)以及深拷貝淺拷貝的相關(guān)資料,希望通過本文能幫助到大家,讓大家實(shí)現(xiàn)這樣的方法,需要的朋友可以參考下2017-10-10
C++實(shí)現(xiàn)LeetCode(163.缺失區(qū)間)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(163.缺失區(qū)間),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07

