热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

模拟实现通讯录动态的方法

模拟实现通讯录-静态的方法:http:blog.csdn.netqq_34328833articledetails51377345题目描述:实现一个通讯

    模拟实现通讯录-静态的方法:

    


http://blog.csdn.net/qq_34328833/article/details/51377345

题目描述:

实现一个通讯录:通讯录可以用于存储1000个人的信息:每个人的信息包括:姓名,性别,年龄,电话,住址

 提供的方法:

1.添加联系人信息

2.删除指定联系人信息

3.查找指定联系人信息

4.修改指定联系人信息

5.显示所有联系人信息

6.清空联系人信息

7.以名字排序所有联系人

模拟实现通讯录-动态的方法:

【题目分析】:

要理解动态实现通讯录首先必须了解动态内存开辟的几个常见的函数,在我们的代码实现过程中我们用到了 free,malloc,realloc 这几个动态内存开辟的函数,下面我们就来介绍这几个函数的功能以及如何使用:

        malloc :打开MSDN我们发现malloc它的函数原型为:void *malloc(size_t size) ,size它是你要分配的字节数,而malloc它的返回值类型是void *,所以一般情况下我们都把分配好的空间强制类型转化成你要使用的类型,用malloc分配的空间要判断是否为空的情况,下面提供一种判断空的方法:

        

char *p=(char *)malloc(10*sizeof(char));if(p == NULL){printf("out of menory");exit(EXIT_FAILURE);}


        free: 它的函数原型为:void free(void *memblock), free一般和malloc配套使用,用于释放堆上的空间;

        realloc: 它的函数原型为:void *realloc(void *memblock,size_t size), realloc函数用于修改一个原本已经分配的内存块的大小,使用这个函数,你可以使一块内存扩大或者缩小;realloc使内存扩大,那仫这块内存的内容依然保留,新增加的内容添加到原先内存块的后面,在实现通讯录的添加联系人功能时,我们设置的初始容量是2,那仫是不是就不可以继续添加了呢?此时我们的realloc就闪亮登场了,我们知道realloc有一个功能就是用于扩容这不就解决了增容的问题了吗?实现如下:

       

void Add(Pcon pcon) //添加联系人
{if(pcon->size >= pcon->capacity){PerInfo *tmp=(PerInfo *)realloc(pcon->data,(pcon->capacity+MAX_RISE)*sizeof(PerInfo)); //当实际联系人个数和初始化的容量相等时用realloc增容if(tmp == NULL){printf("out of menory\n");exit(EXIT_FAILURE);}else{pcon->data=tmp;pcon->capacity+=MAX_RISE;}}printf("请输入你添加之后的联系人信息:(姓名 年龄 性别 联系电话 住址):\n");scanf("%s",pcon->data[pcon->size].name);scanf("%d",&(pcon->data[pcon->size].age));scanf("%s",pcon->data[pcon->size].sex);scanf("%s",pcon->data[pcon->size].tele);scanf("%s",pcon->data[pcon->size].addr);pcon->size++;printf("添加成功\n");
}
         realloc的另一个功能就是用于缩小一个内存块:此时该内存的尾部内存便会被拿掉,剩余部分内存原先的内容会依然保留; 如果realloc函数的第一个参数是NULL,那仫此时它的操作就和malloc一样


          calloc: 它的函数原型为:void *calloc(size_t num,size_t size) ,num:所需元素的数量,size:每个元素的字节数它的作用和malloc类似, calloc将分配好的内存初始化为0而malloc并没有将内存初始化为0 ,也就是说calloc=malloc+memset ;




  

好了理解了这下常见的内存分配函数我们就来实现动态的通讯录吧!得意

在这里附上程序源代码便于读者理解:微笑

#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
#define NAME_MAXNUM 20
#define SEX_MAXNUM 5
#define TELE_MAXNUM 12
#define ADDR_MAXNUM 10
#define MAX 1000
#define MAX_INIT 2
#define MAX_RISE 2
enum OP
{EXIT, ADD,DEL,SEARCH,REVISE,DISPLAY,EMPTY,SORT
};
typedef struct PerInfo
{char name[NAME_MAXNUM];int age;char sex[SEX_MAXNUM];char tele[TELE_MAXNUM];char addr[ADDR_MAXNUM];
}PerInfo;
typedef struct Contact
{PerInfo *data; //存储所有联系人的所有信息int size; //记录联系人的个数int capacity; //通讯录的容量
}Contact,*Pcon;void init(Pcon pcon)
{//memset(pcon->data,0,MAX*sizeof(PerInfo));//pcon->size=0;pcon->data=(PerInfo *)malloc(MAX_INIT*sizeof(PerInfo));if(pcon->data == NULL){printf("out of menory");exit(EXIT_FAILURE);}pcon->size=0;pcon->capacity=MAX_INIT;
}void menu()
{printf("***************简易通讯录***************\n");printf("****1.添加联系人*******2.删除联系人****\n");printf("****3.查找联系人*******4.修改联系人****\n");printf("****5.显示联系人*******6.清空联系人****\n");printf("****7.以名字排序联系人*0.退出**********\n");printf("***************************************\n");
}void Add(Pcon pcon) //添加联系人
{if(pcon->size >= pcon->capacity){PerInfo *tmp=(PerInfo *)realloc(pcon->data,(pcon->capacity+MAX_RISE)*sizeof(PerInfo)); //当实际联系人个数和初始化的容量相等时用realloc增容if(tmp == NULL){printf("out of menory\n");exit(EXIT_FAILURE);}else{pcon->data=tmp;pcon->capacity+=MAX_RISE;}}printf("请输入你添加之后的联系人信息:(姓名 年龄 性别 联系电话 住址):\n");scanf("%s",pcon->data[pcon->size].name);scanf("%d",&(pcon->data[pcon->size].age));scanf("%s",pcon->data[pcon->size].sex);scanf("%s",pcon->data[pcon->size].tele);scanf("%s",pcon->data[pcon->size].addr);pcon->size++;printf("添加成功\n");
}int Find_position(Pcon pcon,char *str) //查找联系人函数
{int i=0;for(i=0;i

size;i++){if(strcmp(pcon->data[i].name,str) == 0) //将要查找的姓名与通讯录里的联系人匹配,找到就返回下标{return i;}}return -1;
}void Del(Pcon pcon) //删除指定联系人
{int ret=0;int i=0;char str[NAME_MAXNUM]={0};printf("请输入你要删除的联系人姓名:");scanf("%s",str);ret=Find_position(pcon,str);if(ret != -1){for(i=ret;i

size;i++){pcon->data[i]=pcon->data[i+1]; //删除的元素之后的元素往前挪一个位置}pcon->size--;}else{printf("通讯录里没有此联系人\n");return ;}
}void Search(Pcon pcon) //查找指定联系人
{int ret=0;char str[NAME_MAXNUM]={0};printf("请输入你要查找的联系人的名字:");scanf("%s",str);ret=Find_position(pcon,str);if(ret != -1){printf("查找成功\n");}else{printf("通讯录里无此人\n");return ;}
}void Revise(Pcon pcon) //修改指定联系人
{int ret=0;char str[NAME_MAXNUM]={0};printf("请输入你要修改的联系人的姓名:");scanf("%s",str);ret=Find_position(pcon,str);if(ret != -1){int input=0;printf("请输入你要修改的信息:1.姓名2.年龄3.性别4.联系电话5.住址\n");scanf("%d",&input);switch(input){case 1:printf("请输入修改后的名字:\n");scanf("%s",pcon->data[ret].name);break;case 2:printf("请输入修改后的年龄:\n");scanf("%d",&(pcon->data[ret].age));break;case 3:printf("请输入修改后的性别:\n");scanf("%s",pcon->data[ret].sex);break;case 4:printf("请输入修改后的联系电话:\n");scanf("%s",pcon->data[ret].tele);break;case 5:printf("请输入修改后的住址:\n");scanf("%s",pcon->data[ret].addr);break;default:printf("error");break;}}else{printf("通讯录里无此人\n");return ;}
}void Display(Pcon pcon) //显示联系人信息
{int i=0;for(i=0;i

size;i++){printf("%s %d %s %s %s\n",pcon->data[i].name,pcon->data[i].age,pcon->data[i].sex,\pcon->data[i].tele,pcon->data[i].addr);}
}void Empty(Pcon pcon) //清空联系人
{pcon->size=0;
}void Sort_name(Pcon pcon) //以名字排序联系人
{int flag=0;int i=0;int j=0;for(i=0;i

size-1;i++){flag=0; //对冒泡排序的优化for(j=0;j

size-1-i;j++){if(strcmp(pcon->data[j].name,pcon->data[j+1].name) > 0) //默认升序排列{PerInfo tmp=pcon->data[j];pcon->data[j]=pcon->data[j+1];pcon->data[j+1]=tmp;flag=1;}}if(flag == 0)break;}
}void Free(Pcon pcon)
{free(pcon->data);pcon->data=NULL;exit(0);
}int main()
{Contact pcon;int intput=1;init(&pcon);while(intput){menu();printf("请输入一个你要选择的操作:");scanf("%d",&intput);if(intput >= 0 && intput <= 7){switch(intput){case ADD:Add(&pcon);break;case DEL:Del(&pcon);break;case SEARCH:Search(&pcon);break;case REVISE:Revise(&pcon);break;case DISPLAY:Display(&pcon);break;case EMPTY:Empty(&pcon);break;case SORT:Sort_name(&pcon);break;case EXIT:Free(&pcon);break;}}}system("pause");return 0;
}
          在这里以一句话勉励自己:敢于尝试才可能成功,加油!


推荐阅读
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文介绍了如何利用JavaScript或jQuery来判断网页中的文本框是否处于焦点状态,以及如何检测鼠标是否悬停在指定的HTML元素上。 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • Docker的安全基准
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
author-avatar
李国龙度_476
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有