如何用C语言编写一个支持长尾词查询的静态通讯录程序?

2026-04-12 07:561阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1729个文字,预计阅读时间需要7分钟。

如何用C语言编写一个支持长尾词查询的静态通讯录程序?

目录

一、项目需求

二、Contact.h

三、Contact.c

1.静态函数

2.初始化通讯录

3.打印

4.添加联系人信息

5.通过名字查找

6.删除联系人信息

7.修改信息

8.排序通讯录

9.清空通讯录

目录
  • 一、项目要求
  • 二、Contact.h
  • 三、Contact.c
    • 1、静态函数
    • 2、初始化通讯录
    • 3、打印
    • 4、增加联系人信息
    • 5、通过名字查找
    • 6、删除联系人信息
    • 7、修改信息
    • 8、排序通讯录
    • 9、清空通讯录
  • 四、text.c
    • 五、动图展示

      一、项目要求

      实现一个通讯录

      通讯录可以用来存储100个人的信息,每个人的信息包括:姓名、性别、年龄、电话、住址

      提供方法:

      • 添加联系人信息
      • 删除指定联系人信息
      • 查找指定联系人信息
      • 修改指定联系人信息
      • 显示所有联系人信息
      • 清空所有联系人
      • 以名字排序所有联系人

      二、Contact.h

      #pragma once #define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <assert.h> #include <string.h> #include <stdlib.h> #define MAX_NAME 20 #define MAX_SEX 10 #define MAX_TELE 12 #define MAX_ADDR 30 #define MAX_CAPACITY 100 typedef struct PeoInfo { char name[MAX_NAME]; char sex[MAX_SEX]; char tele[MAX_TELE]; char addr[MAX_ADDR]; int age; }PeoInfo; typedef struct Contact { PeoInfo date[MAX_CAPACITY]; int size; }Contact; void ContactInit(Contact* pc);//初始化通讯录 void ContactPrint(const Contact* pc);//打印 void ContactAdd(Contact* pc);//增加联系人信息 void ContactDel(Contact* pc);//删除联系人信息 void ContactFind(const Contact* pc);//查找信息 void ContactModify(Contact* pc);//修改信息 void ContactSortByName(Contact* pc);//排序 void ContactEmpty(Contact* pc);//清空通讯录

      先定义一个PeoInfo的结构体类型,里面包含了人的信息。

      再将PeoInfo的数组和数组有效元素个数size包含至Contact,作为通讯录的模板。

      三、Contact.c

      1、静态函数

      static int FindByName(const Contact* pc,const char arr[])//通过名字查找 { assert(pc&&arr); for (int i = 0; i < pc->size; i++) { if (strcmp(pc->date[i].name, arr) == 0) { return i; } } return -1; }

      可以通过名字查找通讯录中是否存在联系人,存在返回下标,不存在返回-1

      2、初始化通讯录

      void ContactInit(Contact* pc)//初始化通讯录 { assert(pc); pc->size = 0; memset(pc->date, 0, sizeof(pc->date)); }

      将size置为0,使用memset函数将pc->date的内存按字节全部置为0

      3、打印

      void ContactPrint(const Contact* pc)//打印 { assert(pc); printf("姓名\t性别\t电话\t地址\t年龄\n"); for (int i = 0; i < pc->size; i++) { printf("%s\t%s\t%s\t%s\t%d\n", pc->date[i].name, pc->date[i].sex, pc->date[i].tele, pc->date[i].addr, pc->date[i].age); } }

      for循环遍历打印pc->date中的结构体成员

      4、增加联系人信息

      void ContactAdd(Contact* pc)//增加联系人信息 { assert(pc&&pc->size<= MAX_CAPACITY); printf("请输入姓名:\n"); scanf("%s", pc->date[pc->size].name); printf("请输入性别:\n"); scanf("%s", pc->date[pc->size].sex); printf("请输入电话:\n"); scanf("%s", pc->date[pc->size].tele); printf("请输入地址:\n"); scanf("%s", pc->date[pc->size].addr); printf("请输入年龄:\n"); scanf("%d", &(pc->date[pc->size].age)); pc->size++; }

      注意增加联系人后pc->size++

      5、通过名字查找

      void ContactFind(const Contact* pc)//查找信息 { assert(pc); printf("请输入姓名查找:"); char arr[20] = { 0 }; scanf("%s", arr); int pos = FindByName(pc, arr); if (pos != -1) { printf("查找到如下信息:\n"); printf("姓名\t性别\t电话\t地址\t年龄\n"); printf("%s\t%s\t%s\t%s\t%d\n", pc->date[pos].name, pc->date[pos].sex, pc->date[pos].tele, pc->date[pos].addr, pc->date[pos].age); } else printf("通讯录查无此人!\n"); }

      先判断查找的信息是否在通讯录中,再打印该下标的信息。

      6、删除联系人信息

      void ContactDel(Contact* pc)//删除联系人信息 { assert(pc); printf("请输入姓名查找:"); char arr[20]={0}; scanf("%s", arr); int pos = FindByName(pc, arr);//记录size的位置 if (pos==-1) { printf("通讯录没有该信息\n"); return; } for (int i = pos; i < pc->size - 1; i++)//移动元素 { pc->date[i] = pc->date[i + 1]; } pc->size--; printf("删除成功!\n"); }

      通过静态函数FindByName返回的下标,通过for循环将后续元素逐个进行覆盖。

      7、修改信息

      void ContactModify(Contact* pc)//修改信息 { assert(pc); printf("请输入姓名查找:"); char arr[20] = { 0 }; scanf("%s", arr); int pos = FindByName(pc, arr); if (pos == -1) { printf("找不到\n"); return; } else { printf("请输入更改后的姓名:\n"); scanf("%s", pc->date[pos].name); printf("请输入更改后的性别:\n"); scanf("%s", pc->date[pos].sex); printf("请输入更改后的电话:\n"); scanf("%s", pc->date[pos].tele); printf("请输入更改后的地址:\n"); scanf("%s", pc->date[pos].addr); printf("请输入更改后的年龄:\n"); scanf("%d", &(pc->date[pos].age)); } }

      先判断查找的信息是否在通讯录中,再打印该下标的信息。

      8、排序通讯录

      int name_cmp(const void* e1, const void* e2) { return strcmp(((PeoInfo*)e1)->name,((PeoInfo*)e2)->name); } void ContactSortByName(Contact* pc)//排序 { assert(pc&&pc->size!=0); qsort(pc->date, pc->size, sizeof(PeoInfo), name_cmp); printf("排序完成\n"); }

      使用qsort函数排序通讯录,可参照本文学习qsort排序结构体的方法

      9、清空通讯录

      void ContactEmpty(Contact* pc)//清空通讯录 { assert(pc); ContactInit(pc); printf("通讯录已清空\n"); }

      本文为静态通讯录,非动态开辟内存,此处使用初始化函数即可。

      四、text.c

      #include "contact.h" void menu() { printf("###########################\n"); printf("#####1、add 2、del######\n"); printf("#####3、find 4、modify###\n"); printf("#####5、print 6、sort#####\n"); printf("#####7、empty 8、exit#####\n"); printf("###########################\n"); } enum option { ADD=1, DEL, FIND, MODIFY, PRINT, SORT, EMPTY, EXIT }; int main() { int input = 0; Contact c;//创建一个通讯录 ContactInit(&c);//初始化通讯录 while (1) { menu(); printf("请输入选项:\n"); scanf("%d", &input); if (input == ADD) ContactAdd(&c);//增加联系人信息 else if (input == DEL) ContactDel(&c);//删除联系人信息 else if (input == FIND) ContactFind(&c);//查找联系人信息 else if (input == MODIFY) ContactModify(&c);//修改联系人信息 else if (input == PRINT) ContactPrint(&c);//打印 else if (input == SORT) ContactSortByName(&c);//排序 else if (input == EMPTY) ContactEmpty(&c);//清空通讯录 else if (input == EXIT) break;//退出 else printf("输入错误!请重新输入!\n"); } return 0; }

      使用enum枚举选项。

      五、动图展示

      以上就是基于C语言实现静态通讯录的示例代码的详细内容,更多关于C语言静态通讯录的资料请关注自由互联其它相关文章!

      如何用C语言编写一个支持长尾词查询的静态通讯录程序?
      标签:示例代码

      本文共计1729个文字,预计阅读时间需要7分钟。

      如何用C语言编写一个支持长尾词查询的静态通讯录程序?

      目录

      一、项目需求

      二、Contact.h

      三、Contact.c

      1.静态函数

      2.初始化通讯录

      3.打印

      4.添加联系人信息

      5.通过名字查找

      6.删除联系人信息

      7.修改信息

      8.排序通讯录

      9.清空通讯录

      目录
      • 一、项目要求
      • 二、Contact.h
      • 三、Contact.c
        • 1、静态函数
        • 2、初始化通讯录
        • 3、打印
        • 4、增加联系人信息
        • 5、通过名字查找
        • 6、删除联系人信息
        • 7、修改信息
        • 8、排序通讯录
        • 9、清空通讯录
      • 四、text.c
        • 五、动图展示

          一、项目要求

          实现一个通讯录

          通讯录可以用来存储100个人的信息,每个人的信息包括:姓名、性别、年龄、电话、住址

          提供方法:

          • 添加联系人信息
          • 删除指定联系人信息
          • 查找指定联系人信息
          • 修改指定联系人信息
          • 显示所有联系人信息
          • 清空所有联系人
          • 以名字排序所有联系人

          二、Contact.h

          #pragma once #define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <assert.h> #include <string.h> #include <stdlib.h> #define MAX_NAME 20 #define MAX_SEX 10 #define MAX_TELE 12 #define MAX_ADDR 30 #define MAX_CAPACITY 100 typedef struct PeoInfo { char name[MAX_NAME]; char sex[MAX_SEX]; char tele[MAX_TELE]; char addr[MAX_ADDR]; int age; }PeoInfo; typedef struct Contact { PeoInfo date[MAX_CAPACITY]; int size; }Contact; void ContactInit(Contact* pc);//初始化通讯录 void ContactPrint(const Contact* pc);//打印 void ContactAdd(Contact* pc);//增加联系人信息 void ContactDel(Contact* pc);//删除联系人信息 void ContactFind(const Contact* pc);//查找信息 void ContactModify(Contact* pc);//修改信息 void ContactSortByName(Contact* pc);//排序 void ContactEmpty(Contact* pc);//清空通讯录

          先定义一个PeoInfo的结构体类型,里面包含了人的信息。

          再将PeoInfo的数组和数组有效元素个数size包含至Contact,作为通讯录的模板。

          三、Contact.c

          1、静态函数

          static int FindByName(const Contact* pc,const char arr[])//通过名字查找 { assert(pc&&arr); for (int i = 0; i < pc->size; i++) { if (strcmp(pc->date[i].name, arr) == 0) { return i; } } return -1; }

          可以通过名字查找通讯录中是否存在联系人,存在返回下标,不存在返回-1

          2、初始化通讯录

          void ContactInit(Contact* pc)//初始化通讯录 { assert(pc); pc->size = 0; memset(pc->date, 0, sizeof(pc->date)); }

          将size置为0,使用memset函数将pc->date的内存按字节全部置为0

          3、打印

          void ContactPrint(const Contact* pc)//打印 { assert(pc); printf("姓名\t性别\t电话\t地址\t年龄\n"); for (int i = 0; i < pc->size; i++) { printf("%s\t%s\t%s\t%s\t%d\n", pc->date[i].name, pc->date[i].sex, pc->date[i].tele, pc->date[i].addr, pc->date[i].age); } }

          for循环遍历打印pc->date中的结构体成员

          4、增加联系人信息

          void ContactAdd(Contact* pc)//增加联系人信息 { assert(pc&&pc->size<= MAX_CAPACITY); printf("请输入姓名:\n"); scanf("%s", pc->date[pc->size].name); printf("请输入性别:\n"); scanf("%s", pc->date[pc->size].sex); printf("请输入电话:\n"); scanf("%s", pc->date[pc->size].tele); printf("请输入地址:\n"); scanf("%s", pc->date[pc->size].addr); printf("请输入年龄:\n"); scanf("%d", &(pc->date[pc->size].age)); pc->size++; }

          注意增加联系人后pc->size++

          5、通过名字查找

          void ContactFind(const Contact* pc)//查找信息 { assert(pc); printf("请输入姓名查找:"); char arr[20] = { 0 }; scanf("%s", arr); int pos = FindByName(pc, arr); if (pos != -1) { printf("查找到如下信息:\n"); printf("姓名\t性别\t电话\t地址\t年龄\n"); printf("%s\t%s\t%s\t%s\t%d\n", pc->date[pos].name, pc->date[pos].sex, pc->date[pos].tele, pc->date[pos].addr, pc->date[pos].age); } else printf("通讯录查无此人!\n"); }

          先判断查找的信息是否在通讯录中,再打印该下标的信息。

          6、删除联系人信息

          void ContactDel(Contact* pc)//删除联系人信息 { assert(pc); printf("请输入姓名查找:"); char arr[20]={0}; scanf("%s", arr); int pos = FindByName(pc, arr);//记录size的位置 if (pos==-1) { printf("通讯录没有该信息\n"); return; } for (int i = pos; i < pc->size - 1; i++)//移动元素 { pc->date[i] = pc->date[i + 1]; } pc->size--; printf("删除成功!\n"); }

          通过静态函数FindByName返回的下标,通过for循环将后续元素逐个进行覆盖。

          7、修改信息

          void ContactModify(Contact* pc)//修改信息 { assert(pc); printf("请输入姓名查找:"); char arr[20] = { 0 }; scanf("%s", arr); int pos = FindByName(pc, arr); if (pos == -1) { printf("找不到\n"); return; } else { printf("请输入更改后的姓名:\n"); scanf("%s", pc->date[pos].name); printf("请输入更改后的性别:\n"); scanf("%s", pc->date[pos].sex); printf("请输入更改后的电话:\n"); scanf("%s", pc->date[pos].tele); printf("请输入更改后的地址:\n"); scanf("%s", pc->date[pos].addr); printf("请输入更改后的年龄:\n"); scanf("%d", &(pc->date[pos].age)); } }

          先判断查找的信息是否在通讯录中,再打印该下标的信息。

          8、排序通讯录

          int name_cmp(const void* e1, const void* e2) { return strcmp(((PeoInfo*)e1)->name,((PeoInfo*)e2)->name); } void ContactSortByName(Contact* pc)//排序 { assert(pc&&pc->size!=0); qsort(pc->date, pc->size, sizeof(PeoInfo), name_cmp); printf("排序完成\n"); }

          使用qsort函数排序通讯录,可参照本文学习qsort排序结构体的方法

          9、清空通讯录

          void ContactEmpty(Contact* pc)//清空通讯录 { assert(pc); ContactInit(pc); printf("通讯录已清空\n"); }

          本文为静态通讯录,非动态开辟内存,此处使用初始化函数即可。

          四、text.c

          #include "contact.h" void menu() { printf("###########################\n"); printf("#####1、add 2、del######\n"); printf("#####3、find 4、modify###\n"); printf("#####5、print 6、sort#####\n"); printf("#####7、empty 8、exit#####\n"); printf("###########################\n"); } enum option { ADD=1, DEL, FIND, MODIFY, PRINT, SORT, EMPTY, EXIT }; int main() { int input = 0; Contact c;//创建一个通讯录 ContactInit(&c);//初始化通讯录 while (1) { menu(); printf("请输入选项:\n"); scanf("%d", &input); if (input == ADD) ContactAdd(&c);//增加联系人信息 else if (input == DEL) ContactDel(&c);//删除联系人信息 else if (input == FIND) ContactFind(&c);//查找联系人信息 else if (input == MODIFY) ContactModify(&c);//修改联系人信息 else if (input == PRINT) ContactPrint(&c);//打印 else if (input == SORT) ContactSortByName(&c);//排序 else if (input == EMPTY) ContactEmpty(&c);//清空通讯录 else if (input == EXIT) break;//退出 else printf("输入错误!请重新输入!\n"); } return 0; }

          使用enum枚举选项。

          五、动图展示

          以上就是基于C语言实现静态通讯录的示例代码的详细内容,更多关于C语言静态通讯录的资料请关注自由互联其它相关文章!

          如何用C语言编写一个支持长尾词查询的静态通讯录程序?
          标签:示例代码