C語言實現(xiàn)電話簿項目
本文實例為大家分享了C語言實現(xiàn)電話簿項目的具體代碼,供大家參考,具體內(nèi)容如下
實現(xiàn)思路
這個程序的整體思路和實現(xiàn)還是很簡單的,我們利用了動態(tài)分配內(nèi)存的方式首先創(chuàng)建了電話簿聯(lián)系人類型,然后創(chuàng)建電話簿類,其實事聯(lián)系人類型構(gòu)成的全局數(shù)組,然后分別實現(xiàn),界面函數(shù),增刪改查打印等功能,在主函數(shù)離實現(xiàn)總體思路,利用while循環(huán)讓用戶選擇具體功能調(diào)用函數(shù)的方式進行總體實現(xiàn)。
————————————————————————
2019.3.12更新:
利用文件操作使得系統(tǒng)可以進行數(shù)據(jù)的保存。
實現(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; } //擴容 void Realloc(AddressBook* addr_book) { assert(addr_book != NULL); //1、擴大capacity的取值 addr_book->capacity *= 2; //2、申請一個更大的內(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); //此處每次擴容闊多少由我們自己定制 printf("擴容成功!\n"); } //新增 void AddAddressBook(AddressBook* addr_book) { assert(addr_book != NULL); if(addr_book->size >= addr_book->capacity) { printf("空間已滿進行擴容!\n"); Realloc(addr_book);//擴容 } printf("請輸入聯(lián)系人信息!\n"); AddressInfo* p = &addr_book->infos[addr_book->size]; printf("請輸入聯(lián)系人姓名:"); scanf("%s", p->name); printf("請輸入聯(lián)系人電話:"); scanf("%s", p->phone); addr_book->size++; printf("添加成功!\n"); return; } //刪除 void DelAddressBook(AddressBook* addr_book) { assert(addr_book != NULL); int id; printf("請輸入要刪除的聯(lián)系人序號:"); 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("修改聯(lián)系人!\n"); printf("請輸入需要修改的聯(lián)系人序號:"); 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("顯示所有聯(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("確定要清除全部信息么,確定請輸入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);//擴容 } 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; } //文件存儲 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條數(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); } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++與QML進行數(shù)據(jù)交互實現(xiàn)方式介紹
迫于無奈開始寫android的程序,以前使用QWidget的方式試過,雖然界面可以實現(xiàn),但是最后調(diào)用攝像頭時,未能成功,再沒有繼續(xù)。這幾天開始使用qml進行嘗試,在使用的過程中,其中的一個難點,就是在qml與c++中數(shù)據(jù)的交互2022-09-09C++ 將字符串值賦給CHAR數(shù)組的實現(xiàn)
這篇文章主要介紹了C++ 將字符串值賦給CHAR數(shù)組的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01C語言數(shù)組和指針,內(nèi)存之間的關(guān)系
這篇文章主要介紹了C語言數(shù)組和指針,內(nèi)存之間的關(guān)系,首先論證一維數(shù)組和一級指針之前的關(guān)系,我們常常使用一級指針指針的方式訪問一維數(shù)組,只有對內(nèi)存的理解到位才能理解它們直接的關(guān)系。需要的小伙伴可以參考一下2022-02-02