一个班有n个学生,需要把每个学生的简单材料(姓名和学号)输入计算机保存。然后可以通过输入某一学生的姓名查找其有关资料。

本文主要是介绍一个班有n个学生,需要把每个学生的简单材料(姓名和学号)输入计算机保存。然后可以通过输入某一学生的姓名查找其有关资料。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

当输入一个姓名后,程序就查找该班中有无此学生,如果有,则输出他的姓名和学号,如果查不到,则输出"本班无此人"。
        为解此问题,可以分别编写两个函数,函数input_data用来输人n个学生的姓名和学号,函数search用来查找要找的学生是否在本班。

编写程序:

运行结果:

程序分析:
        程序第4行定义了两个字符串数组name和num,分别存放全班学生的姓名和学号,它们是全局变量(定义的位置在所有函数的前面),这样各函数都可以直接使用这两个数组。读者可以看到:函数input_data和search都引用了数组name和num,但在这两个函数中并没有定义这两个数组。由于它们是全局变量,因此在input_data函数中向name和num数组输入的数据,search函数可以直接引用。这里定义name和num数组的大小为50(一般班级的人数不会超过50,因此定义为50足够了),在运行时,用户输入班级实际人数n,然后在input_data 中输入n个学生的数据。
        在输入学生数据时,为了方便用户,先输出提示"input name and number of student",然后输出i+1。例如当i为0时,输出的提示是:请输入第1个学生的姓名和学号。这是考虑到用户的习惯,如果提示用户输入学生0的数据,用户显然会感到别扭。在编写应用程序时,一定要考虑程序的使用者是谁,在大多数情况下,程序的使用者并不是程序设计者本人,而是对C++不熟悉,甚至对计算机不熟悉的人,因此程序设计者要设身处地为用户着想,使输入输出的界面对用户友好亲切。
        在主函数输入要找的学生的姓名find_name,然后调用search函数进行寻找。在search函数中将find_name和全班学生姓名逐个相比,如果其中有某一个学生的姓名与find_name的值相同,就表示找到了,输出该学生的姓名name[i]和学号num[i],并使布尔变量flag的值由false改变为true,然后用 break中止循环。如果经过n次比较,全班无学生姓名与find_name相同,for循环就结束了,此时flag的值保持为false。因此在结束循环后,如果测试出flag的值为false,就表示"本班无此人",输出"找不到"的信息。
        这是一个练习程序,所以简单一些。可以对程序稍加修改,使一个学生的数据包括姓名、学号、性别、年龄、各门课的成绩等多个项目,通过姓名的检索,找出一个学生的各种数据。

        通过这个例子可以看到:由于在C++类库中提供了string类,允许程序设计者用string定义字符串变量,这就简化了操作,把原来复杂的问题简单化了,这是C++对C的一个重要补充。
        归纳起来,C++对字符串的处理有两种方法:一种是用字符数组的方法,这是C语言采取的方法,一般称为C-string方法;另一种是用string类定义字符串变量,称为string 方法。显然,string 方法概念清楚,使用方便,最好采用这种方法。C++保留C-string方法主要是为了与C兼容,使以前用C写的程序能用于C++环境。

这篇关于一个班有n个学生,需要把每个学生的简单材料(姓名和学号)输入计算机保存。然后可以通过输入某一学生的姓名查找其有关资料。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1021963

相关文章

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 10130 简单背包

题意: 背包和 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <queue>#include <map>

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能