真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

C語言實現(xiàn)靜態(tài)通訊錄-創(chuàng)新互聯(lián)

目錄

創(chuàng)新互聯(lián)建站是專業(yè)的阿拉善盟網(wǎng)站建設公司,阿拉善盟接單;提供網(wǎng)站設計、網(wǎng)站建設,網(wǎng)頁設計,網(wǎng)站設計,建網(wǎng)站,PHP網(wǎng)站建設等專業(yè)做網(wǎng)站服務;采用PHP框架,可快速的進行阿拉善盟網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

一.模塊設計

二.text.c

1.開始菜單

2.main()函數(shù)的設計

三.contact.h與contact.c里主要函數(shù)的實現(xiàn)

1.添加聯(lián)系人AddContact

2.刪除聯(lián)系人DelContact

3.查找聯(lián)系人SearchContact

4.修改聯(lián)系人ModifyContact

5.顯示所有聯(lián)系人ShowContact

6.排序聯(lián)系人SortByName

四.源碼及運行實況

1.text.c

2.contact.c

3.contact.h


一.模塊設計

采用多文件的形式:

1.test.c? ? ? ? ? //測試通訊錄,包含main(),menu()

2.contact.h? ? ? ?//包含頭文件及實現(xiàn)通訊錄所需函數(shù)的聲明

3.contact.c? ? ? ?//實現(xiàn)通訊錄所需函數(shù)的實現(xiàn)

二.text.c 1.開始菜單

我們首先設計“menu()”函數(shù)來模擬實現(xiàn)對通訊錄最初的選擇

menu()具有以下功能:

1.add? ? ? ?//添加聯(lián)系人

2.del? ? ? ? //刪除聯(lián)系人

3.search? //查找聯(lián)系人

4.modify? //修改聯(lián)系人

5.show? ? //顯示所有聯(lián)系人

6.sort? ? ? //排序聯(lián)系人

0.exit? ? ? //退出

并且為了不只選擇一次就結束,應將menu()函數(shù)放到循環(huán)里,當客戶輸入0.exit時程序才結束。?

具體代碼如下:

void menu()
{
	printf("************************************\n");
	printf("******  1. add    2. del      ******\n");
	printf("******  3. search 4. modify   ******\n");
	printf("******  5. show   6. sort     ******\n");
	printf("******  0. exit               ******\n");
	printf("************************************\n");
}
int input = 0;
do
{
	menu();
	printf("請選擇:>");
	scanf("%d", &input);
	switch(input)
	{
	case 1:
		break;
	case 2:
		break;
	case 3:
		break;
	case 4:
		break;
	case 5:
		break;		
    case 6:;
		break;
	case 7:
		break;
	case 0:
		printf("退出通訊錄\n");
		break;
	default:
		printf("選擇錯誤,請重新選擇\n");
		break;
	}while(input);
2.main()函數(shù)的設計

要實現(xiàn)一個通訊錄,需要用到一個人的姓名、性別、地址等信息,我們將這些信息封裝在結構體中,因此增刪查改某個人的信息也就是增刪查改一個結構體的信息,我們用函數(shù)分別實現(xiàn)這些功能

//人的信息
typedef struct PeoInfo
{
	char name[NAME_MAX];
	int age;
	char sex[SEX_MAX];
	char addr[ADDR_MAX];
	char tele[TELE_MAX];
}PeoInfo;


typedef struct Contact
{
	PeoInfo data[MAX];//存放人的信息的
	int sz;           //當前已經(jīng)放的信息的個數(shù)
}Contact;

在沒有添加任何人的信息之前,通訊錄結構體里信息量理應為0,因此我們應初始化以下;

void InitContact(Contact* pc)
{
	assert(pc);
	pc->sz = 0;
	memset(pc->data, 0, sizeof(pc->data));
}

所以main( )函數(shù)如下:?

int main()
{
	int input = 0;

	Contact con;

	InitContact(&con);

	do
	{
		menu();
		printf("請選擇:>");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			AddContact(&con);
			break;
		case 2:
			DelContact(&con);
			break;
		case 3:
			SearchContact(&con);
			break;
		case 4:
			ModifyContact(&con);
			break;
		case 5:
			ShowContact(&con);
			break;
		case 6:
			qsort(&con, con.sz, sizeof(con.data[0]), cmp);
			break;
		case 0:
			printf("退出通訊錄\n");
			break;
		default:
			printf("選擇錯誤,請重新選擇\n");
			break;
		}
	} while (input);

	return 0;
}
三.contact.h與contact.c里主要函數(shù)的實現(xiàn) 1.添加聯(lián)系人AddContact

注:如果通訊錄滿了,就無法添加新成員,故需特判一下。

void AddContact(Contact* pc)
{
	assert(pc);
	if (pc->sz == MAX)
	{
		printf("通訊錄已滿,無法添加\n");
		return;
	}
	//增加一個人的信息
	printf("請輸入名字:>");
	scanf("%s", pc->data[pc->sz].name);
	printf("請輸入年齡:>");
	scanf("%d", &(pc->data[pc->sz].age));
	printf("請輸入性別:>");
	scanf("%s", pc->data[pc->sz].sex);
	printf("請輸入地址:>");
	scanf("%s", pc->data[pc->sz].addr);
	printf("請輸入電話:>");
	scanf("%s", pc->data[pc->sz].tele);

	pc->sz++;
}

void AddContact(Contact* pc)?;函數(shù)聲明放到contact.h里

2.刪除聯(lián)系人DelContact

我們需要先查找指定的聯(lián)系人,再刪除,這和后面的實現(xiàn)查找聯(lián)系人函數(shù)和實現(xiàn)修改聯(lián)系人函數(shù)有重疊的代碼塊,都是先查找到指定的聯(lián)系人,再執(zhí)行下一步操作,因此我們把查找的過程封裝為另一個函數(shù)FindByName,遇到查找直接調(diào)用即可:

int FindByName(const Contact* pc, char name[])
{
	assert(pc);

	int i = 0;
	for (i = 0; i< pc->sz; i++)
	{
		if (strcmp(pc->data[i].name, name) == 0)
		{
			return i;
		}
	}
	return -1;
}
void DelContact(Contact* pc)
{
	assert(pc);

	char name[NAME_MAX] = {0};
	if (pc->sz == 0)
	{
		printf("通訊錄為空,無法刪除\n");
		return;
	}
	//刪除
	//找到要刪除的人
	printf("請輸入要刪除的人的名字:>");
	scanf("%s", name);
	int ret = FindByName(pc, name);
	if (-1 == ret)
	{
		printf("要刪除的人不存在\n");
		return;
	}

	int i = 0;
	//刪除
	for (i = ret; i< pc->sz-1; i++)
	{
		pc->data[i] = pc->data[i + 1];
	}
	pc->sz--;
	printf("刪除成功\n");
}

void DelContact(Contact* pc) ;函數(shù)聲明放到contact.h里

3.查找聯(lián)系人SearchContact
void SearchContact(const Contact* pc)
{
	assert(pc);
	char name[NAME_MAX] = {0};
	printf("請輸入要查找人的名字:>");
	scanf("%s", name);
	int pos = FindByName(pc, name);
	if (-1 == pos)
	{
		printf("要查找的人不存在\n");
		return;
	}
	//打印信息
	printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\n", "名字", "年齡", "性別", "地址", "電話");
	printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\n", pc->data[pos].name,
			pc->data[pos].age,
			pc->data[pos].sex,
			pc->data[pos].addr,
			pc->data[pos].tele);
}
4.修改聯(lián)系人ModifyContact
void ModifyContact(Contact* pc)
{
	assert(pc);
	char name[NAME_MAX] = { 0 };
	printf("請輸入要修改人的名字:>");
	scanf("%s", name);
	int pos = FindByName(pc, name);
	if (-1 == pos)
	{
		printf("要修改的人不存在\n");
		return;
	}

	printf("請輸入名字:>");
	scanf("%s", pc->data[pos].name);
	printf("請輸入年齡:>");
	scanf("%d", &(pc->data[pos].age));
	printf("請輸入性別:>");
	scanf("%s", pc->data[pos].sex);
	printf("請輸入地址:>");
	scanf("%s", pc->data[pos].addr);
	printf("請輸入電話:>");
	scanf("%s", pc->data[pos].tele);

	printf("修改完成\n");
}
5.顯示所有聯(lián)系人ShowContact
void ShowContact(const Contact* pc)
{
	assert(pc);
	int i = 0;
	printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\n", "名字", "年齡", "性別", "地址", "電話");
	for (i = 0; i< pc->sz; i++)
	{
		printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\n", pc->data[i].name,
		pc->data[i].age,
		pc->data[i].sex,
		pc->data[i].addr,
		pc->data[i].tele);
	}
}
6.排序聯(lián)系人SortByName

按名字排序,也就是按字符串排序,使用qsort()函數(shù)實現(xiàn)

//qsort
int cmp(const void* s1, const void* s2)
{
	assert(s1 && s2);
	return strcmp((char*)s1, (char*)s2);
}
四.源碼及運行實況 1.text.c
#define _CRT_SECURE_NO_WARNINGS 1


#include "contact.h"

void menu()
{
	printf("************************************\n");
	printf("******  1. add    2. del      ******\n");
	printf("******  3. search 4. modify   ******\n");
	printf("******  5. show   6. sort     ******\n");
	printf("******  0. exit               ******\n");
	printf("************************************\n");
}

int main()
{
	int input = 0;

	Contact con;

	InitContact(&con);

	do
	{
		menu();
		printf("請選擇:>");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			AddContact(&con);
			break;
		case 2:
			DelContact(&con);
			break;
		case 3:
			SearchContact(&con);
			break;
		case 4:
			ModifyContact(&con);
			break;
		case 5:
			ShowContact(&con);
			break;
		case 6:
			qsort(&con, con.sz, sizeof(con.data[0]), cmp);
			break;
		case 0:
			printf("退出通訊錄\n");
			break;
		default:
			printf("選擇錯誤,請重新選擇\n");
			break;
		}
	} while (input);

	return 0;
}
2.contact.c
#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"

void InitContact(Contact* pc)
{
	assert(pc);
	pc->sz = 0;
	memset(pc->data, 0, sizeof(pc->data));
}

void AddContact(Contact* pc)
{
	assert(pc);
	if (pc->sz == MAX)
	{
		printf("通訊錄已滿,無法添加\n");
		return;
	}
	//增加一個人的信息
	printf("請輸入名字:>");
	scanf("%s", pc->data[pc->sz].name);
	printf("請輸入年齡:>");
	scanf("%d", &(pc->data[pc->sz].age));
	printf("請輸入性別:>");
	scanf("%s", pc->data[pc->sz].sex);
	printf("請輸入地址:>");
	scanf("%s", pc->data[pc->sz].addr);
	printf("請輸入電話:>");
	scanf("%s", pc->data[pc->sz].tele);

	pc->sz++;
}


void ShowContact(const Contact* pc)
{
	assert(pc);
	int i = 0;
	printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\n", "名字", "年齡", "性別", "地址", "電話");
	for (i = 0; i< pc->sz; i++)
	{
		printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\n", pc->data[i].name,
			pc->data[i].age,
			pc->data[i].sex,
			pc->data[i].addr,
			pc->data[i].tele);
	}
}


int FindByName(const Contact* pc, char name[])
{
	assert(pc);

	int i = 0;
	for (i = 0; i< pc->sz; i++)
	{
		if (strcmp(pc->data[i].name, name) == 0)
		{
			return i;
		}
	}
	return -1;
}

void DelContact(Contact* pc)
{
	assert(pc);

	char name[NAME_MAX] = { 0 };
	if (pc->sz == 0)
	{
		printf("通訊錄為空,無法刪除\n");
		return;
	}
	//刪除
	//找到要刪除的人
	printf("請輸入要刪除的人的名字:>");
	scanf("%s", name);
	int ret = FindByName(pc, name);
	if (-1 == ret)
	{
		printf("要刪除的人不存在\n");
		return;
	}

	int i = 0;
	//刪除
	for (i = ret; i< pc->sz - 1; i++)
	{
		pc->data[i] = pc->data[i + 1];
	}
	pc->sz--;
	printf("刪除成功\n");
}

void SearchContact(const Contact* pc)
{
	assert(pc);
	char name[NAME_MAX] = { 0 };
	printf("請輸入要查找人的名字:>");
	scanf("%s", name);
	int pos = FindByName(pc, name);
	if (-1 == pos)
	{
		printf("要查找的人不存在\n");
		return;
	}
	//打印信息
	printf("%-20s\t%-4s\t%-5s\t%-20s\t%-12s\n", "名字", "年齡", "性別", "地址", "電話");
	printf("%-20s\t%-4d\t%-5s\t%-20s\t%-12s\n", pc->data[pos].name,
		pc->data[pos].age,
		pc->data[pos].sex,
		pc->data[pos].addr,
		pc->data[pos].tele);
}


void ModifyContact(Contact* pc)
{
	assert(pc);
	char name[NAME_MAX] = { 0 };
	printf("請輸入要修改人的名字:>");
	scanf("%s", name);
	int pos = FindByName(pc, name);
	if (-1 == pos)
	{
		printf("要修改的人不存在\n");
		return;
	}

	printf("請輸入名字:>");
	scanf("%s", pc->data[pos].name);
	printf("請輸入年齡:>");
	scanf("%d", &(pc->data[pos].age));
	printf("請輸入性別:>");
	scanf("%s", pc->data[pos].sex);
	printf("請輸入地址:>");
	scanf("%s", pc->data[pos].addr);
	printf("請輸入電話:>");
	scanf("%s", pc->data[pos].tele);

	printf("修改完成\n");
}

//qsort
int cmp(const void* s1, const void* s2)
{
	assert(s1 && s2);
	return strcmp((char*)s1, (char*)s2);
}
3.contact.h
#pragma once

#include#include#include 


#define MAX 100
#define NAME_MAX 20
#define SEX_MAX 5
#define ADDR_MAX 30
#define TELE_MAX 12

//人的信息
typedef struct PeoInfo
{
	char name[NAME_MAX];
	int age;
	char sex[SEX_MAX];
	char addr[ADDR_MAX];
	char tele[TELE_MAX];
}PeoInfo;


typedef struct Contact
{
	PeoInfo data[MAX];//存放人的信息的
	int sz;//當前已經(jīng)放的信息的個數(shù)
}Contact;

//初始化通訊錄
void InitContact(Contact* pc);

//增加聯(lián)系人
void AddContact(Contact* pc);

//刪除指定聯(lián)系人
void DelContact(Contact* pc);

//顯示通訊錄中的信息
void ShowContact(const Contact* pc);

//查找指定聯(lián)系人
void SearchContact(const Contact* pc);

//修改指定聯(lián)系人
void ModifyContact(Contact* pc);

//按名字排序通訊錄
int cmp(const void* s1, const void* s2);

本篇到此結束,碼文不易,還請多多支持哦!

你是否還在尋找穩(wěn)定的海外服務器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機房具備T級流量清洗系統(tǒng)配攻擊溯源,準確流量調(diào)度確保服務器高可用性,企業(yè)級服務器適合批量采購,新人活動首月15元起,快前往官網(wǎng)查看詳情吧


新聞名稱:C語言實現(xiàn)靜態(tài)通訊錄-創(chuàng)新互聯(lián)
URL分享:http://weahome.cn/article/dodocc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部