中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C語言實現通訊錄的代碼怎么寫

發布時間:2021-12-28 13:11:18 來源:億速云 閱讀:163 作者:柒染 欄目:開發技術

這期內容當中小編將會給大家帶來有關C語言實現通訊錄的代碼怎么寫,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

(一)實現思路

1.通訊錄功能

添加好友,刪除好友,查找好友,修改好友信息,對好友進行排序

2.模塊化實現各方面的功能

a. test.c

測試通訊錄功能

b. Contact.c

實現通訊錄功能

c. Contact.h

包含通訊錄實現的頭文件

3.代碼實現

(二)源代碼

A.test.c

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#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("***  7.Help        8.About0 ***\n");
	printf("***  0.Exit                 ***\n");
	printf("*******************************\n");
}
 
 
int main()
{
 
	int input = 0;
	//創建通訊錄
	int size = 0;
	struct Contact con;//一個結構體里包含1000個人的信息和size;
	//size表示的是該通訊錄里現在的好友數
	//初始化通訊錄
	InitContact(&con);//使size的初始值,以及好友信息初始化為0;
	do
	{
		menu();
		printf("請選擇:");
		scanf("%d", &input);
		switch (input)
		{
			//添加好友信息
		case Add:
			AddContact(&con);
			break;
			//刪除好友
 
		case Del:
			DelContact(&con);
			break;
 
			//查找好友信息
		case Search:
			SearchContact(&con);
			break;
 
			//修改好友信息
		case Modify:
			ModifyContact(&con);
			break;
 
			//顯示好友信息
		case Show:
			ShowContact(&con);
			break;
 
			//好友排序
		case Sort:
			SortContact(&con);
			break;
 
			//退出
		case Exit:
			printf("退出通訊錄!");
			break;
 
			//通訊錄的使用以及幫助
		case Help:
			HelpContact();
			break;
 
			//關于通訊錄
		case About:
			AboutContact();
			break;
 
			//選擇錯誤
		default:
			printf("選擇錯誤!");
			break;
		}
 
	} while (input);
	return 0;
}

B.Contact.h

#define _CRT_SECURE_NO_WARNINGS 1
#define Max 1000
#define Max_name 20
#define Max_sex 5
#define Max_tele 12
#define Max_addr 30
 
enum Option
{
	Exit,
	Add,
	Del,
	Search,
	Modify,
	Show,
	Sort,
	Help,
	About
 
};
 
 
//創建一個結構體來存放通訊錄中要存放的信息
struct PeoInfo
{
	char name[Max_name];
	int age;
	char sex[Max_sex];
	char tele[Max_tele];
	char addr[Max_addr];
};
 
//通訊錄類型
struct Contact
{
	struct PeoInfo data[Max];//存放一個信息,包括好友姓名,年齡,性別,電話,地址
	int size;//記錄當前已經有的元素個數
	//存入一個好友,size加1,表示通訊錄人數增加一個
};
 
 
//聲明函數
//1.對通訊錄進行初始化
void InitContact(struct Contact* ps);
 
//增加好友信息
void AddContact(struct Contact* ps);
 
//刪除好友
void DelContact(struct Contact* ps);
 
//查找指定姓名的好友
void SearchContact(struct Contact* ps);
 
//顯示好友信息
void ShowContact(const struct Contact* ps);
 
//修改好友信息
void ModifyContact( struct Contact* ps);
 
//按名字首字母對通訊錄的好友進行排序
void SortContact( struct Contact* ps);
 
//幫助使用通訊錄
void HelpContact();
 
//關于通訊錄
void AboutContact();

C.Contact.c

#define _CRT_SECURE_NO_WARNINGS 1
 
#include "contact.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
//初始化通訊錄
void InitContact(struct Contact* ps)
{
	memset(ps->data, 0, sizeof(ps->data));
	ps->size = 0;//設置通訊錄最初只有0個元素
}
 
 
//幫助使用通訊錄
void HelpContact()
{
	printf("各按鍵的使用:\n");
	printf("1.添加好友\n");
    printf("2.刪除好友\n");
	printf("3.查找好友信息\n");
	printf("4.修改好友信息\n");
	printf("5.顯示好友信息\n");
	printf("6.對好友進行排序\n");
	printf("7.幫助使用通訊錄\n");
	printf("8.關于通訊錄\n");
	printf("謝謝使用通訊錄!\n");
 
}
 
//關于通訊錄
void AboutContact()
{
	printf("通訊錄一般指在日常生活中用筆記錄,也在手機,電腦,電子字典等電子產品中擁有這個功能。\n");
}
 
 
//增加好友的電話,信息
void AddContact(struct Contact* ps)
{
	if (ps->size == Max)
	{
		printf("通訊錄已滿,無法增加!\n");
	}
	else
	{
		printf("請輸入姓名:");
		scanf("%s", ps->data[ps->size].name);
		//除了年齡,其他都是數組,直接用數組名
		printf("請輸入年齡:");
		scanf("%d", &(ps->data[ps->size].age));
		//年齡不是數組,則需要&
		printf("請輸入性別:");
		scanf("%s", ps->data[ps->size].sex);
		printf("請輸入電話:");
		scanf("%s", ps->data[ps->size].tele);
		printf("請輸入地址:");
		scanf("%s", ps->data[ps->size].addr);
		ps->size++;
		//添加成功一個1好友,size加1,;
		printf("添加成功!\n");
	}
 
}
 
 
//在刪除,查找,修改的函數中均涉及查找到該好友才能進行
//為了避免冗余,我們把查找的這個環節從函數中抽離出來
//在函數中直接使用,就不會顯得重復
 
static int Find_by_name(struct Contact* ps, char name[Max_name])
{
	int i;
	for (i = 0; i < ps->size; i++)
	{
		//將要查找的好友姓名與通訊錄中的好友進行比較
		if (0 == strcmp(ps->data[i].name, name))
		{
			//若找到,返回其下標
			return i;
		}
	}
	//若都循環,比對完了以后還沒找到就返回-1
	return -1;
}
 
 
//刪除好友信息
void DelContact(struct Contact* ps)
{
	int  j;
	char name[Max_name];
	printf("請輸入刪除好友的名字:");
	scanf("%s", name);
	//1.查找要刪除的人的位置
	int pos = Find_by_name(ps, name);
	//調用函數進行查找,若找到,返回下標,若沒找到,返回-1;
	//2.刪除
	if (pos==-1)
	{
		printf("該好友不存在!\n");
	}
	else
	{
		//刪除數據
		for (j = pos; j < ps->size - 1; j++)
		{
			ps->data[j] = ps->data[j + 1];
			//刪除數據后,后面的元素位置都改變,向前移動一個位置;
		}
		ps->size--;
		//刪除一個好友,size-1.
		printf("刪除成功!\n");
	}
}
 
 
//查找指定好友信息
void SearchContact(struct Contact* ps)
{
	char name[Max_name];
	printf("輸入要查找的好友姓名:");
	scanf("%s", name);
	int pos = Find_by_name(ps, name);
	if (pos ==-1)
	{
		printf("該好友不存在!\n");
	}
	else
	{
		printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年齡", "性別", "電話", "地址");
		printf("%10s\t%4d\t%5s\t%12s\t%20s\n",
			ps->data[pos].name,
			ps->data[pos].age,
			ps->data[pos].sex,
			ps->data[pos].tele,
			ps->data[pos].addr);
	}
 
}
 
//修改好友信息
void ModifyContact(struct Contact* ps)
{
	
	char name[Max_name];
	printf("請輸入需要修改信息的好友姓名:");
	scanf("%s", name);
	int pos=Find_by_name(ps, name);
	if (pos == -1)
	{
		printf("該用戶不存在!\n");
	}
	else
	{
		printf("請輸入姓名:");
		scanf("%s", ps->data[pos].name);
		printf("請輸入年齡:");
		scanf("%d", &(ps->data[pos].age));
		printf("請輸入性別:");
		scanf("%s", ps->data[pos].sex);
		printf("請輸入電話:");
		scanf("%s", ps->data[pos].tele);
		printf("請輸入地址:");
		scanf("%s", ps->data[pos].addr);
		printf("修改成功!\n");
	}
 
}
 
 
//顯示出好友的基本信息
void ShowContact(const struct Contact* ps)
{
	if (ps->size == 0)
	{
		printf("通訊錄為空!\n");
	}
	else
	{
		int i = 0;
		printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年齡", "性別", "電話", "地址");
		for (i = 0; i < ps->size; i++)
		{
			printf("%10s\t%4d\t%5s\t%12s\t%20s\n",
				ps->data[i].name,
				ps->data[i].age,
				ps->data[i].sex,
				ps->data[i].tele,
				ps->data[i].addr);
				
		}
	}
}
 
 
//按照名字的首字母進行排序
 
int cmp_stu_by_name(const void* e1, const void* e2)
{
	return (strcmp(((struct Contact*)e1)->data->name, ((struct Contact*)e2)->data->name));
}
 
 
//我們用qsort()函數對我們的好友按照名字首字母進行排序
void SortContact( struct Contact* ps)
{
	qsort(ps->data, ps->size, sizeof(ps->data[0]), cmp_stu_by_name);
	printf("%10s\t%4s\t%5s\t%12s\t%20s\n", "名字", "年齡", "性別", "電話", "地址");
	int i;
	for (i = 0; i < ps->size; i++)
	{
		printf("%10s\t%4d\t%5s\t%12s\t%20s\n",
			ps->data[i].name,
			ps->data[i].age,
			ps->data[i].sex,
			ps->data[i].tele,
			ps->data[i].addr);
	}
}

上述就是小編為大家分享的C語言實現通訊錄的代碼怎么寫了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宜良县| 朝阳市| 东安县| 应城市| 巨野县| 宜君县| 宁夏| 道孚县| 四川省| 怀集县| 治县。| 巨野县| 化州市| 宁化县| 承德县| 丹巴县| 和龙市| 通州区| 宜君县| 丰城市| 嘉义县| 安徽省| 当雄县| 鸡泽县| 宜阳县| 衡阳市| 丰顺县| 彭州市| 九龙县| 内江市| 博乐市| 伊金霍洛旗| 江北区| 从化市| 太湖县| 临安市| 葫芦岛市| 吴江市| 治多县| 台南县| 佛冈县|