您好,登錄后才能下訂單哦!
C語(yǔ)言實(shí)現(xiàn)一個(gè)通訊錄,通訊錄可以用來(lái)存儲(chǔ)1000個(gè)人的信息,每個(gè)人的信息包括:
姓名、性別、年齡、電話、住址
**提供方法:
1. 添加聯(lián)系人信息
2. 刪除指定聯(lián)系人信息
3. 查找指定聯(lián)系人信息
4. 修改指定聯(lián)系人信息
5. 顯示所有聯(lián)系人信息
6. 清空所有聯(lián)系人
7. 以名字排序所有聯(lián)系人**
思路分析:
首先我們可以分三個(gè)模塊來(lái)解決這個(gè)問(wèn)題,第一個(gè)模塊我們需要一個(gè)頭文件,這個(gè)頭文件里可以包含一些相應(yīng)信息,當(dāng)實(shí)現(xiàn)文件和測(cè)試文件包含自己定義的頭文件時(shí)便可以獲得一些相關(guān)的信息。所以頭文件里應(yīng)該包括一個(gè)結(jié)構(gòu)體,這個(gè)結(jié)構(gòu)體里應(yīng)包含姓名,性別,年齡,電話,住址。同時(shí)還可以定義一個(gè)結(jié)構(gòu)體,這個(gè)結(jié)構(gòu)體里包含通訊錄,同時(shí)通訊錄里人員的計(jì)數(shù)變量,將通訊錄的地址傳到別的地方便可以實(shí)現(xiàn)對(duì)它遍歷或者其他操作。
第二個(gè)模塊便是我們的測(cè)試函數(shù),測(cè)試函數(shù)便可以實(shí)現(xiàn)我們的菜單打印,同時(shí)由我們接收不同的值便可以實(shí)現(xiàn)不同的操作,就是相應(yīng)的方法的實(shí)現(xiàn),這里很明顯可以通過(guò)一個(gè)switch語(yǔ)句來(lái)進(jìn)行控制。
第三個(gè)模塊便是我們的方法實(shí)現(xiàn)的函數(shù),將模塊2里定義的類型為通訊錄的地址傳到各個(gè)方法里,這樣便可以實(shí)現(xiàn)對(duì)通訊錄的操作。
1.linkman.h(頭文件)
#ifndef __LINKMAN_H__ #define __LINKMAN_H__ #include<stdio.h> #include<windows.h> #include<string.h> #pragma warning (disable:4996) typedef struct LINKMAN//建立結(jié)構(gòu)體,存放聯(lián)系人信息 { char name[20]; char sex[10]; int age; int tel[12]; char addr[50]; }LINKMAN; typedef struct Statis //把通訊錄和人員統(tǒng)計(jì)放在結(jié)構(gòu)體內(nèi) { LINKMAN num[1000]; int count; }Statis; void inint_linkman(Statis *p);//初始化數(shù)組 void Add_linkman(Statis *p);// 添加聯(lián)系人信息 void Dele_linkman(Statis *p);//刪除指定聯(lián)系人信息 void Find_linkman(Statis *p);//查找指定聯(lián)系人信息 void Revise_linkman(Statis *p);//修改指定聯(lián)系人信息 void Display_linkman(Statis *p);//顯示所有聯(lián)系人信息 void Empty_linkman(Statis *p);//清空所有聯(lián)系人 void sort_linkman(Statis *p);//以名字排序所有聯(lián)系人 #endif
2.test.c(測(cè)試)
#include "linkman.h" Statis sta; void menu()//菜單 { printf("***********************************\n"); printf("********1.添加聯(lián)系人信息***********\n"); printf("********2.刪除指定聯(lián)系人信息*******\n"); printf("********3.查找指定聯(lián)系人信息*******\n"); printf("********4.修改指定聯(lián)系人信息*******\n"); printf("********5.顯示所有聯(lián)系人信息*******\n"); printf("********6.清空所有聯(lián)系人***********\n"); printf("********7.以名字排序所有聯(lián)系人*****\n"); printf("**************按0退出程序**********\n"); printf("***********************************\n"); } void test() { int i = 0; do { menu(); printf("請(qǐng)輸入你要進(jìn)行的選項(xiàng):"); scanf("%d", &i); switch (i) { case 1: Add_linkman(&sta); break; case 2: Dele_linkman(&sta); break; case 3: Find_linkman(&sta); break; case 4: Revise_linkman(&sta); break; case 5: Display_linkman(&sta); break; case 6: Empty_linkman(&sta); break; case 7: sort_linkman(&sta); break; case 0: exit(1); break; default: printf("輸入錯(cuò)誤\n"); break; } } while (i); } int main() { inint_linkman(&sta); test(); system("pause"); return 0; }
3.game.c(實(shí)現(xiàn))
#include "linkman.h" void inint_linkman(Statis *p) { int count = sizeof(p->num); p->count = 0; memset(p->num, 0,count); } int Find(Statis *p, char *pname)//對(duì)于一個(gè)聯(lián)系人是否存在封裝一個(gè)函數(shù),在后面的修改、刪除、查找可以用到 { int i = 0; for (i = 0; i < (p->count); i++) { if (strcmp(p->num[i].name, pname) == 0) return i; } return -1; } void menu1()//修改聯(lián)系人時(shí)所用到的菜單 { printf("*********************\n"); printf("****1.姓名*2.性別****\n"); printf("****3.年齡*4.電話****\n"); printf("****5.地址*6.返回****\n"); printf("*********************\n"); } void Add_linkman(Statis *p)//添加聯(lián)系人 { printf("請(qǐng)輸入你要添加的聯(lián)系人姓名:\n"); scanf("%s", p->num[p->count].name); printf("請(qǐng)輸入你要添加的聯(lián)系人性別:\n"); scanf("%s", p->num[p->count].sex); printf("請(qǐng)輸入你要添加的聯(lián)系人年齡:\n"); scanf("%d", &(p->num[p->count].age)); printf("請(qǐng)輸入你要添加的聯(lián)系人電話:\n"); scanf("%s", p->num[p->count].tel); printf("請(qǐng)輸入你要添加的聯(lián)系人地址:\n"); scanf("%s", p->num[p->count].addr); if ((p->count) > 1000) { printf("聯(lián)系人上限\n"); } else { printf("添加成功\n"); p->count++; } } void Dele_linkman(Statis *p)//刪除聯(lián)系人 { char name[20] = { 0 }; int result = 0; int n = 0; int i = 0; printf("請(qǐng)輸入要?jiǎng)h除人的姓名:\n"); scanf("%s", name); result = Find(p, name); if (result != -1) { printf("你是否要?jiǎng)h除該聯(lián)系人?\n"); printf("刪除請(qǐng)按1,不刪除請(qǐng)按0\n"); scanf("%d", &n); if (n == 1) { for (i = 0; i < (p->count)-1; i++) { p->num[i] = p->num[i + 1]; } p->count --; printf("刪除成功\n"); } else { printf("刪除失敗\n"); } } else { printf("你要?jiǎng)h除的聯(lián)系人不存在\n"); } } void Find_linkman(Statis *p)//查找聯(lián)系人 { char name[20] = { 0 }; int result = 0; printf("請(qǐng)輸入要查找聯(lián)系人的姓名:\n"); scanf("%s", name); result = Find(p, name); if (result != -1) { printf("姓名:%s\n", p->num[result].name); printf("性別:%s\n", p->num[result].sex); printf("年齡:%d\n", p->num[result].age); printf("電話:%s\n", p->num[result].tel); printf("地址:%s\n", p->num[result].addr); } else { printf("你要查找的聯(lián)系人不存在\n"); } } void Revise_linkman(Statis *p)//修改聯(lián)系人 { char name[20] = {0}; int result = 0; printf("請(qǐng)輸入你要修改聯(lián)系人的姓名:\n"); scanf("%s", name); result = Find(p, name); if (result != -1) { printf("姓名:%s\n", p->num[result].name); printf("性別:%s\n", p->num[result].sex); printf("年齡:%d\n", p->num[result].age); printf("電話:%s\n", p->num[result].tel); printf("地址:%s\n", p->num[result].addr); int i = 0; do { menu1(); printf("輸入你要修改的選項(xiàng):\n"); scanf("%d", &i); switch (i) { case 1: printf("請(qǐng)把姓名修改成:"); scanf("%s", p->num[result].name); break; case 2: printf("請(qǐng)把性別修改成:"); scanf("%s", p->num[result].sex); break; case 3: printf("請(qǐng)把年齡修改成:"); scanf("%d", &(p->num[result].age)); break; case 4: printf("請(qǐng)把電話修改成:"); scanf("%s", p->num[result].tel); break; case 5: printf("請(qǐng)把地址修改成:"); scanf("%s", p->num[result].addr); break; case 0: break; default: printf("輸入錯(cuò)誤"); break; } } while (i); } else { printf("你要修改的聯(lián)系人不存在\n"); } } void Display_linkman(Statis *p)//打印所有聯(lián)系人信息 { int i = 0; printf("輸出所有人的信息:\n"); printf("%10s%7s%6s%8s%10s\n","名字","性別","年齡","電話","住址"); for (i = 0; i <(p->count); i++) { printf("%11s", p->num[i].name); printf("%5s", p->num[i].sex); printf("%5d", p->num[i].age); printf("%10s", p->num[i].tel); printf("%12s", p->num[i].addr); printf("\n"); } } void Empty_linkman(Statis *p)//清空聯(lián)系人 { p->count = 0; } void sort_linkman(Statis *p)//以名字排序所有聯(lián)系人(冒泡) { int i = 0; int j = 0; for (i = 0; i < p->count - 1; i++) for (j = 0; j < p->count - 1 - i; j++) { if (strcmp(p->num[j].name, p->num[j + 1].name)>0) { LINKMAN tmp; tmp = p->num[j]; p->num[j] = p->num[j + 1]; p->num[j + 1] = tmp; } } }
程序運(yùn)行結(jié)果部分示范:
到此為止,我們的簡(jiǎn)易通訊錄就實(shí)現(xiàn)啦?。?!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。