用c语言编辑一个通讯录,C语言实现一个通讯录
实现一个通讯录,通讯录可以用来存储1000个人的信息,每个人的信息包括:
姓名、性别、年龄、电话、住址
提供方法:
1. 添加联系人信息
2. 删除指定联系人信息
3. 查找指定联系人信息
4. 修改指定联系人信息
5. 显示所有联系人信息
6. 清空所有联系人
7. 以名字排序所有联系人
没有开辟动态内存的方法:
头文件:test.h
#ifndef __CONTACT
#define __CONTACT
#define _CRT_SECURE_NO_WARNINGS 1
#include
#include
#include
#include
#define N 1000
typedef struct contact
{
char name[30];
char gender[10];
int age;
int telephone;
char address[100];
};//结构体没有定义变量属于声明一个结构体类型
void meau();
void show(struct contact *p, int len);//struct contact *p:结构体指针指向这个结构体, int len:结构体数组的长度
void Add_linkman(struct contact *p, int len,int flag);
int Delete_linkman(struct contact *p, int d_number, int len);//int d_number选择要删除第几个结构体的内容
void Find_member(struct contact *p, int d_number, int len);//int d_number表示要查找的第几个结构体的内容(即联系人的信息)
void empty(struct contact *p);
void Modify(struct contact *p, int M_member);//int M_member:要修改的第几个联系人
int cmp(const void *a, const void *b);//qsort里面的比较函数定义任意类型
void sort(struct contact *p, int len);//根据联系人的名字进行排序
#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
{
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("不存在该联系人:");
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("修改之前联系人的信息为:");
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;//定义一个标志位来结构体数组中每个结构体的位置
int total = N;
int delete_number = 0;
meau();
while (1)
{
printf("请输入数字进行选择:");
scanf("%d", &num);
switch (num)
{
case 1:{
printf("请添加len个学生的信息:");
scanf("%d", &len);
Add_linkman(student,len+flag,flag);
flag=flag+len;
}break;
case 2:{
printf("请输入要删除的第i个学生的信息:");
scanf("%d", &delete_number);
Delete_linkman(student, delete_number, len+flag);
flag = flag - 1;
}break;
case 3:{
int Find_number = 0;
printf("请输入要查找的第i个学生的信息:");
scanf("%d", &Find_number);
Find_member(student, delete_number, len+flag);
}break;
case 4:{
printf("清空所有联系人:");
empty(student);
}break;
case 5:{
printf("请输入要修改的的第i个学生的信息:");
int M_member = 0;
scanf("%d", &M_member);
Modify(student, M_member);
}break;
case 6:{
printf("根据名字排序所有联系人:\n");
sort(student, len+flag);
}break;
case 7:{
printf("打印所有联系人的信息:\n");
show(student, flag);
}break;
case 0:{
exit(1);
}
default:printf("enter error data!!!");
}
}
system("pause");
return 0;
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
用c语言编辑一个通讯录,C语言实现一个通讯录相关推荐
- c语言编辑编译链接,C语言的“编译、链接”
我们写的代码,仅仅是文本文件(txt),不管后缀怎么变,终究是文本文件,计算机只能显示,不能做事(执行). 文本文件通过"编译.链接",成为可执行文件(windows下是exe): ...
- c语言编辑机器人行走,c语言课程设计报告-步行机器人.doc
c语言课程设计报告-步行机器人 PAGE 第 PAGE \* Arabic \* MERGEFORMAT 17 页第 PAGE \* Arabic \* MERGEFORMAT 17 页第 PAGE ...
- c语言编辑三色球问题,C语言实例编程:三色球问题
若一个口袋中放有12个球,其中有3个红的.3个白的和6个黒的,问从中任取8个共有多少种不同的颜色搭配? *问题分析与算法设计 设任取的红球个数为i,白球个数为j,则黒球个数为8-i-j,根据题意红球和 ...
- C语言编辑个人信息,C语言实现的个人信息管理系统
#include "main.h" void find_id(int id) { int i=0; for(i=0;iname); /**********ID输入********* ...
- c语言编辑数学公式,用C语言编个公式数学公式求助
满意答案 zsao1125 2018.11.08 采纳率:54% 等级:12 已帮助:17631人 函数名及解释:int abs(int i) 返回整型参数i的绝对值double cabs(st ...
- c语言编辑删除学生,c语言学生管理系统之学生信息删除
void DeleteStudentInformation(LINK head , long w) //删除 ...
- c语言fac函数求n的阶乘,急求C语言编辑题:Cnm=n!/m!(n-m)!其中n,m 由键盘输入。要求设计一个函数fac(n)求某个正整数n 的阶乘。...
急求C语言编辑题:Cnm=n!/m!(n-m)!其中n,m 由键盘输入.要求设计一个函数fac(n)求某个正整数n 的阶乘. 來源:互聯網 2010-05-29 01:44:10 評論 分類: 電 ...
- c语言编程等腰三角形,用c语言编辑一个等腰三角形的讲解过程 一个等腰三角形怎么平均分成三个面积相等的三角形?...
导航:网站首页 > 用c语言编辑一个等腰三角形的讲解过程 一个等腰三角形怎么平均分成三个面积相等的三角形? 用c语言编辑一个等腰三角形的讲解过程 一个等腰三角形怎么平均分成三个面积相等的三角形? ...
- n的阶乘 计算机程序设计艺术,急求C语言编辑题:Cnm=n!/m!(n-m)!其中n,m 由键盘输入。要求设计一个函数fac(n)求某个正整数n 的阶乘。...
急求C语言编辑题:Cnm=n!/m!(n-m)!其中n,m 由键盘输入.要求设计一个函数fac(n)求某个正整数n 的阶乘. 来源:互联网 宽屏版 评论 2010-05-29 01:44:10 分 ...
- 《C语言小程序篇---1》——实现一个“富婆通讯录“(超详细)
目录 前言: 一.富婆通讯录应该有什么: 二 有了富婆的信息后,我们怎么更方便实现它的功能? 三 代码实现 1.创建菜单交互界面 2.创建主函数实现分支功能 3.定义联系人和通讯录 3.1.定义联系人 ...
最新文章
- R语言生存分析(survival analysis)与生存资料有关的概念详解
- 设计模式所遵循的原则及模式之间的关系
- python返回unicode_Python 中通过 unicode 码返回单字符的函数是 ,返回单字符 unicode 码的函数是 。_学小易找答案...
- iOS进阶之底层原理-线程与进程、gcd
- JavaScript原始类型转换和进制转换
- mvc4 html.beginform,MVC4 Html.BeginForm在Internet Explorer中提交按钮 9不工
- android 管理类,android 线程管理类
- spring集成compass中出现的问题和总结
- 关于iframe或document监听滑动(scroll)失败的问题
- orc识别较慢_超强orc文字识别免注册版
- matlab中求声音的长度,关于声音分贝大小
- Java、JSP网上音像管理系统的设计与实现
- 视频素材-高质量缥缈雾气雾霾特效合成动画 Lens Distortions – Fog II
- java实例分析宠物商店_Java实现宠物商店管理
- 2018安恒杯11月月赛 MISC
- MACS磁珠标记细胞分选技术
- frame切换、多窗口切换
- 浅谈《微信抢红包原理》
- Cmd Markdown
- Idea在Maven项目中使用支付宝沙箱环境
热门文章
- golang修改文件的最后访问时间,最后修改时间
- Hadoop权威指南 _03_第I部分Hadoop基础知识_第1章初识Hadoop.
- Redis03_基础命令操作
- maven中心仓库OSSRH使用简介
- mysql时间与字符串相互转换
- Java - 线程安全的 HashMap 实现方法及原理
- 使用itextpdf操作pdf
- 14.count-api
- zoj 3761 Easy billiards 并查集+dfs
- 【易懂】Java源码角度分析put()与putIfAbsent()的区别——源码分析系列