C語言實(shí)現(xiàn)一個(gè)通訊錄
實(shí)現(xiàn)一個(gè)通訊錄,通訊錄可以用來存儲(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)系人
沒有開辟動(dòng)態(tài)內(nèi)存的方法:
頭文件:test.h
#ifndef __CONTACT #define __CONTACT #define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> #include<stdlib.h> #include<string.h> #include<assert.h> #define N 1000 typedef struct contact { char name[30]; char gender[10]; int age; int telephone; char address[100]; };//結(jié)構(gòu)體沒有定義變量屬于聲明一個(gè)結(jié)構(gòu)體類型 void meau(); void show(struct contact *p, int len);//struct contact *p:結(jié)構(gòu)體指針指向這個(gè)結(jié)構(gòu)體, int len:結(jié)構(gòu)體數(shù)組的長度 void Add_linkman(struct contact *p, int len,int flag); int Delete_linkman(struct contact *p, int d_number, int len);//int d_number選擇要?jiǎng)h除第幾個(gè)結(jié)構(gòu)體的內(nèi)容 void Find_member(struct contact *p, int d_number, int len);//int d_number表示要查找的第幾個(gè)結(jié)構(gòu)體的內(nèi)容(即聯(lián)系人的信息) void empty(struct contact *p); void Modify(struct contact *p, int M_member);//int M_member:要修改的第幾個(gè)聯(lián)系人 int cmp(const void *a, const void *b);//qsort里面的比較函數(shù)定義任意類型 void sort(struct contact *p, int len);//根據(jù)聯(lián)系人的名字進(jìn)行排序 #endif//條件編譯
contact.c文件
#include"test.h" void meau() { printf(" *******************************************\n"); printf(" *******************************************\n"); printf(" ##############My address book##############\n"); printf(" *1-Add 2-Delete 3-Find *\n"); printf(" *4-Empty 5-Modify 6-Sort *\n"); printf(" *0-Exit 7-Show *\n"); printf(" *******************************************\n"); printf(" *******************************************\n"); } void show(struct contact *p, int len) { assert(p); int i = 0; for (i = 0; i < len; i++) { printf("name:%s gender:%s age:%d telephone:%d address:%s", \ p[i].name, p[i].gender, p[i].age, p[i].telephone, p[i].address); printf("\n"); } } void Add_linkman(struct contact *p, int len,int flag) { assert(p); int i = 0; for (i = flag; i < len; i++) { printf("請輸入姓名:"); scanf("%s", &p[i].name); printf("請輸入姓別:"); scanf("%s", &p[i].gender); printf("請輸入年齡:"); scanf("%d", &p[i].age); printf("請輸入電話:"); scanf("%d", &p[i].telephone); printf("請輸入地址:"); scanf("%s", &p[i].address); } } int Delete_linkman(struct contact *p, int d_number, int len) { assert(p); int i = 0; for (i = d_number - 1; i < len - 1; i++) { p[i] = p[i + 1]; } } void Find_member(struct contact *p, int d_number, int len) { assert(p); if (d_number - 1 >= 0 || d_number - 1<len) { printf("name:%s gender:%s age:%d telephone:%d address:%s", \ p[d_number].name, p[d_number].gender, p[d_number].age, p[d_number].telephone, p[d_number].address); printf("\n"); } else { printf("不存在該聯(lián)系人:"); return; } } void empty(struct contact *p) { assert(p); int i = 0; for (i = 0; i <1000; i++) { memset(p+i, 0, sizeof(struct contact)); } } void Modify(struct contact *p, int M_member) { assert(p); printf("修改之前聯(lián)系人的信息為:"); printf("\n"); printf("name:%s gender:%s age:%d telephone:%d address:%s", \ p[M_member - 1].name, p[M_member - 1].gender, p[M_member - 1].age, p[M_member - 1].telephone, p[M_member - 1].address); printf("\n"); printf("請輸入要修改的信息:"); printf("請輸入姓名:"); scanf("%s", &p[M_member - 1].name); printf("請輸入姓別:"); scanf("%s", &p[M_member - 1].gender); printf("請輸入年齡:"); scanf("%d", &p[M_member - 1].age); printf("請輸入電話:"); scanf("%d", &p[M_member - 1].telephone); printf("請輸入地址:"); scanf("%s", &p[M_member - 1].address); } int cmp(const void *a, const void *b) { struct contact *aa = (struct contact *)a; struct contact *bb = (struct contact *)b; if (aa->name != bb->name) return(strcmp((aa->name), (bb->name))); } void sort(struct contact *p, int len) { assert(p); qsort(p, len, sizeof(struct contact), cmp); }
test.c文件:
#include"test.h" int main() { int num = 0; struct contact student[N]; int len = 0; int flag = 0;//定義一個(gè)標(biāo)志位來結(jié)構(gòu)體數(shù)組中每個(gè)結(jié)構(gòu)體的位置 int total = N; int delete_number = 0; meau(); while (1) { printf("請輸入數(shù)字進(jìn)行選擇:"); scanf("%d", &num); switch (num) { case 1:{ printf("請?zhí)砑觢en個(gè)學(xué)生的信息:"); scanf("%d", &len); Add_linkman(student,len+flag,flag); flag=flag+len; }break; case 2:{ printf("請輸入要?jiǎng)h除的第i個(gè)學(xué)生的信息:"); scanf("%d", &delete_number); Delete_linkman(student, delete_number, len+flag); flag = flag - 1; }break; case 3:{ int Find_number = 0; printf("請輸入要查找的第i個(gè)學(xué)生的信息:"); scanf("%d", &Find_number); Find_member(student, delete_number, len+flag); }break; case 4:{ printf("清空所有聯(lián)系人:"); empty(student); }break; case 5:{ printf("請輸入要修改的的第i個(gè)學(xué)生的信息:"); int M_member = 0; scanf("%d", &M_member); Modify(student, M_member); }break; case 6:{ printf("根據(jù)名字排序所有聯(lián)系人:\n"); sort(student, len+flag); }break; case 7:{ printf("打印所有聯(lián)系人的信息:\n"); show(student, flag); }break; case 0:{ exit(1); } default:printf("enter error data!!!"); } } system("pause"); return 0; }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
您可能感興趣的文章
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用函數(shù)刪除字符
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)式函數(shù)庫
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言中對數(shù)函數(shù)的表達(dá)式 c語言中對數(shù)怎么表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段函數(shù)
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排序法函數(shù)
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段函數(shù)
- 04-02C語言中怎么打出三角函數(shù) c語言中怎么打出三角函數(shù)的值
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求階乘


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達(dá)式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機(jī)閱讀
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10delphi制作wav文件的方法
- 08-05織夢dedecms什么時(shí)候用欄目交叉功能?
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 04-02jquery與jsp,用jquery
- 01-11ajax實(shí)現(xiàn)頁面的局部加載