当前位置: 首页 > wzjs >正文

山西高端网站建设学网络营销有用吗

山西高端网站建设,学网络营销有用吗,怎么搭建自己的网站平台,做校招的网站有哪些目录 一、关于通讯录 二、代码逻辑 三、通讯录实现 1.菜单设计 2.逻辑主要功能设计 3.增加联系人功能实现 4.显示全部联系人信息 5.删除联系人 6.查找联系人 7.修改联系人信息 8.对联系人进行排序 9.一键清空所有联系人 四、完整源码 test.c contact.c contact.…

目录

一、关于通讯录

二、代码逻辑

三、通讯录实现

1.菜单设计

2.逻辑主要功能设计

3.增加联系人功能实现

4.显示全部联系人信息 

 5.删除联系人

6.查找联系人

7.修改联系人信息

8.对联系人进行排序

 9.一键清空所有联系人

四、完整源码

test.c

contact.c

contact.h


一、关于通讯录

在通讯录中,我们一般保存联系人的信息,联系人的信息一般会有 姓名、年龄、性别、电话、地址等。在通讯录中,我们也会对一些信息进行增删改查。

二、代码逻辑

代码文件

test.c 用于测试代码

contact.h 用于存放头文件

contact.c 用于主要代码的功能实现

  1. 菜单设计
  2. 功能实现

三、通讯录实现

1.菜单设计

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

 

2.逻辑主要功能设计

因为有了菜单可以进行功能选择

功能实现的前提是  先对通讯录 进行设计 并 初始化

采用结构体进行设计

typedef struct PeoInfo 
{char name[NAME_MAX];int age;char sex[SEX_MAX];char tele[TELE_MAX];char addr[ADDR_MAX];
}PeoInfo;typedef struct Contact 
{PeoInfo data[MAX];//存放通讯录数据int sz;//记录通讯录存了多少个数据
}Contact;

 

通讯录初始化(使用memset 将通讯录数据置0)

//初始化通讯录
void InitContact(Contact *pc) 
{assert(pc);//断言一下,避免空指针//将通讯录数据置0memset(pc->data,0,sizeof(pc->data)); //这里使用的内存函数,也可以使用for循环进行pc->sz = 0;//将记录通讯录信息个数置0
}

采用do ...while 和 switch 进行设计

	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 CLEAR:InitContact(&con);//清空通讯录break;case EXIT:printf("退出通讯录!\n");break;default:Sleep(300);system("cls");//清屏printf("输入错误,请重新输入!\n");}} while (input);

在这里我们发现switch 语句中 的case 选项中的常量表达式 是字母,这里主要是利用了枚举常量。

enum Option 
{EXIT,ADD,DEL,SEARCH,MODIFY,SHOW,SORT,CLEAR
};

EXIT表示0 ,ADD表示1 依次类推... 

这样在switch语句中就增加了代码的可读性和可调试性

3.增加联系人功能实现

//增加联系人
void AddContact(Contact* pc) 
{assert(pc);//首先应该判断通讯录是否已满if (pc->sz == MAX) {printf("通讯录已满,无法添加!\n");return;}Sleep(300);system("cls");//清屏//增加的信息//名字 年龄 性别 电话 地址printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n","名字","年龄","性别","电话","地址");printf("----------------------------------------------------------------------------\n");//增加信息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].tele);printf("请输入地址:");scanf("%s", pc->data[pc->sz].addr);pc->sz++;printf("增加成功\n");Sleep(1000);system("cls");//清屏
}

4.显示全部联系人信息 

上述是增加联系人的信息,既然增加联系人我们就来查看联系人信息

//显示全部联系人
void ShowContact( const Contact* pc)
{assert(pc);if (pc->sz == 0){printf("通讯录为空!\n");Sleep(1000);system("cls");//清屏return;}printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc -> sz;i++){printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-30s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}}

 

 5.删除联系人

这里采用的思想是 数组后面的元素前移将前面的元素覆盖来达到删除该信息的目的

这里是删除指定联系人

//按名字查找
static int FindByName(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);if (pc->sz == 0) {printf("通讯录为空,无法删除!\n");Sleep(1000);system("cls");//清屏return;}char name[NAME_MAX];printf("输入要删除的名字:");scanf("%s",&name);int ret = FindByName(pc,name);if (ret == -1){printf("要删除的联系人不存在\n");Sleep(1000);system("cls");//清屏return;}int i = 0;//进行删除的操作for (i = ret; i < pc->sz - 1;i++) {pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功!\n");Sleep(1000);system("cls");//清屏
}

6.查找联系人

 

//查找联系人
void SearchContact(Contact* pc) 
{assert(pc);char name[NAME_MAX];Sleep(1000);system("cls");//清屏printf("请输入要查找人的名字:");scanf("%s",name);int ret = FindByName(pc, name);if (ret == -1){printf("要查找的联系人不存在\n");//Sleep(1000);//system("cls");//清屏return;}Sleep(1000);system("cls");//清屏//显示出查找的联系人printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-18s\n",pc->data[ret].name,pc->data[ret].age,pc->data[ret].sex,pc->data[ret].tele,pc->data[ret].addr);Sleep(3000);
}

7.修改联系人信息

enum option_menu 
{EXIT,NAME ,AGE,SEX,TELE,ADDR
};
//修改联系人信息
void ModifyContact(Contact* pc) 
{assert(pc);char name[NAME_MAX];printf("请输入要修改联系人的名字:");scanf("%s",name);int ret = FindByName(pc, name);if (ret == -1){printf("要修改的联系人不存在\n");Sleep(1000);system("cls");//清屏return;}//修改联系人printf("**********\n");printf("#1. 名字 *\n#2. 年龄 *\n#3. 性别 *\n#4. 电话 *\n#5. 地址 *\n#0. 返回 *\n");printf("**********\n");int input = 0;do{//option_menu();printf("请选择你要的信息:>\n");scanf("%d", &input);switch (input){case NAME:printf("请输入名字:\n");scanf("%s", pc->data[ret].name);break;case AGE:printf("请输入年龄:\n");scanf("%d", &(pc->data[ret].age));break;case SEX:printf("请输入性别:\n");scanf("%s", pc->data[ret].sex);break;case TELE:printf("请输入电话:\n");scanf("%s", pc->data[ret].tele);break;case ADDR:printf("请输入地址:\n");scanf("%s", pc->data[ret].addr);break;case EXIT:printf("返回主界面\n");return;default:printf("输入错误,请重新输入\n");break;}} while (input);}

 

8.对联系人进行排序

int cmp_name(const void* s1,const void* s2) 
{return strcmp(((Contact*)s1)->data->name, ((Contact*)s2)->data->name);
}
int cmp_age(const void* s1,const void* s2)
{return ((Contact*)s1)->data->age - ((Contact*)s2)->data->age;
}
//排序
void SortContact(Contact* pc) 
{assert(pc);if (pc->sz == 0) {printf("通讯录为空,无法排序 !");return;}int input = 0;printf("***********\n");printf("# 1. 名字 *\n# 2. 年龄 *\n");printf("***********\n");printf("请选择排序的方法:");scanf("%d",&input);if (input == 1) {//按名字进行排序qsort(pc->data, pc->sz, sizeof(PeoInfo), cmp_name);printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc->sz; i++){printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-30s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}}else if (input == 2) {//按年龄进行排序qsort(pc->data, pc->sz, sizeof(PeoInfo), cmp_age);printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc->sz; i++){printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-30s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}}
}

 

先展示一下原来数据的信息

 排序1

排序2

 

 9.一键清空所有联系人

 这里是直接调用的初始化通讯录函数

//初始化通讯录
void InitContact(Contact *pc) 
{assert(pc);//断言一下,避免空指针//将通讯录数据置0memset(pc->data,0,sizeof(pc->data)); //这里使用的内存函数,也可以使用for循环进行pc->sz = 0;//将记录通讯录信息个数置0
}

四、完整源码

test.c

#define _CRT_SECURE_NO_WARNINGS 
//用于测试
#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. clear    0. exit   ******\n");printf("***********************************\n");
}
enum Option 
{EXIT,ADD,DEL,SEARCH,MODIFY,SHOW,SORT,CLEAR
};
int main() 
{int input = 0;Contact con;//con 通讯录对象InitContact(&con);//初始化通讯录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 CLEAR:InitContact(&con);//清空通讯录break;case EXIT:printf("退出通讯录!\n");break;default:Sleep(300);system("cls");//清屏printf("输入错误,请重新输入!\n");}} while (input);return 0;
}

contact.c

#define _CRT_SECURE_NO_WARNINGS 
#include "contact.h"//用于实现函数//初始化通讯录
void InitContact(Contact *pc) 
{assert(pc);//断言一下,避免空指针//将通讯录数据置0memset(pc->data,0,sizeof(pc->data)); //这里使用的内存函数,也可以使用for循环进行pc->sz = 0;//将记录通讯录信息个数置0
}//增加联系人
void AddContact(Contact* pc) 
{assert(pc);//首先应该判断通讯录是否已满if (pc->sz == MAX) {printf("通讯录已满,无法添加!\n");return;}Sleep(300);system("cls");//清屏//增加的信息//名字 年龄 性别 电话 地址printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n","名字","年龄","性别","电话","地址");printf("----------------------------------------------------------------------------\n");//增加信息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].tele);printf("请输入地址:");scanf("%s", pc->data[pc->sz].addr);pc->sz++;printf("增加成功\n");Sleep(1000);system("cls");//清屏
}//显示全部联系人
void ShowContact( const Contact* pc)
{assert(pc);if (pc->sz == 0){printf("通讯录为空!\n");Sleep(1000);system("cls");//清屏return;}printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc -> sz;i++){printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-30s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}}
//按名字查找
static int FindByName(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);if (pc->sz == 0) {printf("通讯录为空,无法删除!\n");Sleep(1000);system("cls");//清屏return;}char name[NAME_MAX];printf("输入要删除的名字:");scanf("%s",&name);int ret = FindByName(pc,name);if (ret == -1){printf("要删除的联系人不存在\n");Sleep(1000);system("cls");//清屏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(Contact* pc) 
{assert(pc);char name[NAME_MAX];Sleep(1000);system("cls");//清屏printf("请输入要查找人的名字:");scanf("%s",name);int ret = FindByName(pc, name);if (ret == -1){printf("要查找的联系人不存在\n");//Sleep(1000);//system("cls");//清屏return;}Sleep(1000);system("cls");//清屏//显示出查找的联系人printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-18s\n",pc->data[ret].name,pc->data[ret].age,pc->data[ret].sex,pc->data[ret].tele,pc->data[ret].addr);Sleep(3000);
}enum option_menu 
{EXIT,NAME ,AGE,SEX,TELE,ADDR
};
//修改联系人信息
void ModifyContact(Contact* pc) 
{assert(pc);char name[NAME_MAX];printf("请输入要修改联系人的名字:");scanf("%s",name);int ret = FindByName(pc, name);if (ret == -1){printf("要修改的联系人不存在\n");Sleep(1000);system("cls");//清屏return;}//修改联系人printf("**********\n");printf("#1. 名字 *\n#2. 年龄 *\n#3. 性别 *\n#4. 电话 *\n#5. 地址 *\n#0. 返回 *\n");printf("**********\n");int input = 0;do{//option_menu();printf("请选择你要的信息:>\n");scanf("%d", &input);switch (input){case NAME:printf("请输入名字:\n");scanf("%s", pc->data[ret].name);break;case AGE:printf("请输入年龄:\n");scanf("%d", &(pc->data[ret].age));break;case SEX:printf("请输入性别:\n");scanf("%s", pc->data[ret].sex);break;case TELE:printf("请输入电话:\n");scanf("%s", pc->data[ret].tele);break;case ADDR:printf("请输入地址:\n");scanf("%s", pc->data[ret].addr);break;case EXIT:printf("返回主界面\n");return;default:printf("输入错误,请重新输入\n");break;}} while (input);}int cmp_name(const void* s1,const void* s2) 
{return strcmp(((Contact*)s1)->data->name, ((Contact*)s2)->data->name);
}
int cmp_age(const void* s1,const void* s2)
{return ((Contact*)s1)->data->age - ((Contact*)s2)->data->age;
}
//排序
void SortContact(Contact* pc) 
{assert(pc);if (pc->sz == 0) {printf("通讯录为空,无法排序 !");return;}int input = 0;printf("***********\n");printf("# 1. 名字 *\n# 2. 年龄 *\n");printf("***********\n");printf("请选择排序的方法:");scanf("%d",&input);if (input == 1) {//按名字进行排序qsort(pc->data, pc->sz, sizeof(PeoInfo), cmp_name);printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc->sz; i++){printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-30s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}}else if (input == 2) {//按年龄进行排序qsort(pc->data, pc->sz, sizeof(PeoInfo), cmp_age);printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc->sz; i++){printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-30s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}}
}

contact.h

#pragma once#include<stdio.h>
#include<assert.h>
#include<string.h>
#include<stdlib.h>
#include<windows.h>#define NAME_MAX 20
#define SEX_MAX 5
#define TELE_MAX 12
#define ADDR_MAX 30#define MAX 1000 //用于存放通信录信息的条数
//用于声明函数typedef struct PeoInfo 
{char name[NAME_MAX];int age;char sex[SEX_MAX];char tele[TELE_MAX];char addr[ADDR_MAX];
}PeoInfo;typedef struct Contact 
{PeoInfo data[MAX];//存放通讯录数据int sz;//记录通讯录存了多少个数据
}Contact;//初始化通讯录
void InitContact(Contact * pc);//增加联系人
void AddContact(Contact* pc);//显示全部联系人
void ShowContact(Contact* pc);//删除联系人
void DelContact(Contact* pc);//查找联系人
void SearchContact(Contact* pc);//修改联系人信息
void ModifyContact(Contact* pc);//排序
void SortContact(Contact* pc);

http://www.dtcms.com/wzjs/466466.html

相关文章:

  • 肃宁网站建设公司营销策划公司取名大全
  • PHP网站新闻发布怎么做百度竞价收费标准
  • 南昌 定制网站百度网页游戏排行榜
  • 什么是电商视觉设计四川seo推广公司
  • 网络公司网站建设服务微帮推广平台怎么加入
  • 网站开发需求分析参考文献网络广告营销策划方案
  • 让别人做网站要注意什么百度竞价广告代理
  • 网站开发新手什么软件好市场营销方案怎么做
  • html5 音乐网站西安百度竞价托管公司
  • 外加工订单网谷歌优化seo
  • 机构改革网站建设北京seo的排名优化
  • 网站结构的规划与设计产品推广语
  • 公司网站建设推广方案模板自己建网站要多少钱
  • 广西委办局网站独立建设政策关键词优化案例
  • 什么网站可以做教师资格证的题云巅seo
  • 做的好的自驾游网站百度seo官方网站
  • 建设营销型网站哪家好推广网页
  • 做面食的网站怎么优化自己网站
  • 大型做网站公司手机百度app安装下载
  • 美国二手表网站成都网站seo服务
  • 金州网站建设网页设计图
  • 岳阳建设网站的公司朋友圈推广文案
  • 西安网站开发培训价格青岛seo网络优化公司
  • 广告牌logo设计制作免费seo快速排名工具
  • 路由下做网站映射推广公司app主要做什么
  • 网站防火墙怎么做网站推广软件免费版下载
  • 班级网站建设毕业设计开题报告河北百度推广
  • 网站做301需要备案吗网站设计制作公司
  • 天津体验网站中视频自媒体平台注册官网
  • 快速 复制 建设网站品牌策划书案例