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

c语言200例 063 信息查询

大家好,欢迎来到无限大的频道。

今天给大家带来的是c语言200例

题目要求:

        从键盘当中输入姓名和电话号,以“#”结束,编程实现输入姓名、查询电话号的功能。

参考代码如下:

#include <stdio.h>
#include <string.h>
#define MAX 16

struct aa {
    char name[15];
    char tel[15];
}; 

int readin(struct aa *a) {
    int i = 0;
 	printf("请输入姓名和电话号码(输入#结束):\n");
    while (i < MAX) {
        printf("姓名: ");
        scanf("%14s", a[i].name);  // 限制输入字符数,避免溢出
        if (strcmp(a[i].name, "#") == 0) {
            break;  // 如果输入名称是#,则结束输入
        }
        printf("电话: ");
        scanf("%14s", a[i].tel);  // 限制输入字符数,避免溢出
        i++;
    }
    return i;  // 返回实际输入的数量
}

void search(struct aa *b, char *x, int n) {
	int i;
    for (i = 0; i < n; i++) {
        if (!strcmp(b[i].name, x)) {
            printf("姓名: %s 电话: %s\n", b[i].name, b[i].tel);
            return;  // 找到后直接返回
        }
    }
    printf("没有找到!\n");
}

int main() {
    struct aa s[MAX];
    int num;
    char name[15];
    num = readin(s);
    printf("输入姓名: ");
    scanf("%14s", name);  // 同样处理
    search(s, name, num);
    return 0;
}

代码分析

  1. 头文件与宏定义
    #include <stdio.h>
    #include <string.h>
    #define MAX 16
    
    • #include <stdio.h>:引入标准输入输出库,用于使用输入输出函数。
    • #include <string.h>:引入字符串处理库,用于字符串的函数(如 strcmp)。
    • #define MAX 16:定义常量 MAX,用于表示最多可以输入16个联系人的信息。
  2. 定义结构体
    struct aa {
        char name[15];
        char tel[15];
    };
    
    • 定义一个名为 aa 的结构体,用于存储每个联系人的姓名和电话号码,各自定义为15个字符的数组。
  3. readin 函数
    int readin(struct aa *a) {
        int i = 0;
        printf("请输入姓名和电话号码(输入#结束):\n");
        while (i < MAX) {
            printf("姓名: ");
            scanf("%14s", a[i].name);  // 限制输入字符数,避免溢出
            if (strcmp(a[i].name, "#") == 0) {
                break;  // 如果输入名称是#,则结束输入
            }
            printf("电话: ");
            scanf("%14s", a[i].tel);  // 限制输入字符数,避免溢出
            i++;
        }
        return i;  // 返回实际输入的数量
    }
    
    • 用于读取用户的姓名和电话号码,最多读取 MAX 条记录。
    • 每次输入时,提示用户输入姓名和电话号码,并存储到结构体数组中。
    • 如果用户输入 #,则结束录入,退出循环。
    • 返回实际录入的数量 i,供后续查找使用。
  4. search 函数
    void search(struct aa *b, char *x, int n) {
        int i;
        for (i = 0; i < n; i++) {
            if (!strcmp(b[i].name, x)) {
                printf("姓名: %s 电话: %s\n", b[i].name, b[i].tel);
                return;  // 找到后直接返回
            }
        }
        printf("没有找到!\n");
    }
    
    • 用于根据用户输入的姓名查找联系人。
    • 遍历 b 数组中的前 n 帧数据(通过 num 传入)并进行比较。
    • 如果找到与输入姓名匹配的联系人,则打印该联系人的姓名和电话号码,并返回。
    • 如果所有数据都遍历完毕且没有结果,输出 “没有找到!”。
  5. main 函数
    int main() {
        struct aa s[MAX];
        int num;
        char name[15];
        num = readin(s);
        printf("输入姓名: ");
        scanf("%14s", name);  // 同样处理
        search(s, name, num);
        return 0;
    }
    
    • main 函数为程序的入口点。
    • 定义一个 struct aa 类型的数组 s 用于存储联系人。
    • 调用 readin 函数以获取用户输入的联系人信息,并返回录入的数量存储在 num 中。
    • 提示用户输入要查询的姓名,并调用 search 函数进行查询。

代码思路总结

  1. 数据输入模块
    • 通过 readin 函数读取用户输入的姓名和电话号码,将数据存储在结构体数组中,直到用户输入第一个“#”进行结束。
  2. 数据查询模块
    • 通过 search 函数根据用户输入的姓名在存储的联系人中查找对应的电话号码并打印结果。
  3. 程序结构
    • 整体结构清晰,逻辑上分为输入、存储和查询三个主要功能模块。各个部分的功能明确,且使用了适当的函数来分隔逻辑。

http://www.kler.cn/a/321524.html

相关文章:

  • Docker在CentOS上的安装与配置
  • Unity教程(十八)战斗系统 攻击逻辑
  • k8s笔记——核心概念
  • 用枚举算法解决LeetCode第3348题最小可整除数位乘积II
  • 【JavaEE初阶 — 多线程】生产消费模型 阻塞队列
  • 前端面试笔试(二)
  • 数据结构 ——— 移除元素(快慢指针)
  • io流(学习笔记03)字符集
  • 大数据时代的PDF解析:技术与挑战
  • Python:百度贴吧实现自动化签到
  • Spring是什么
  • 有源蜂鸣器(5V STM32)
  • 无人机之虚拟云台技术篇
  • LeetCode 137. 只出现一次的数字 II
  • Linux安装vim超详细教程
  • MySQL重点,面试题
  • 深入Android UI开发:从自定义View到高级布局技巧的全面学习资料
  • RestSharp简介
  • 通信工程学习:什么是SDN软件定义网络
  • 电脑如何设置代理IP:详细步骤指南
  • STM32 入门教程(江科大教材)#笔记4
  • 01.前端面试题之ts:说说如何在Vue项目中应用TypeScript?
  • 趣笔阁爬虫实验
  • Hadoop FileSystem Shell 常用操作命令
  • GO Message Bus
  • 【Python报错已解决】AttributeError: ‘tuple‘ object has no attribute ‘log_softmax‘