本文主要是介绍【蓝桥杯选拔赛真题47】C++相邻身高差 第十四届蓝桥杯青少年创意编程大赛 算法思维 C++编程选拔赛真题解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
目录
C++相邻身高差
一、题目要求
1、编程实现
2、输入输出
二、算法分析
三、程序编写
四、程序说明
五、运行结果
六、考点分析
七、推荐资料
C++相邻身高差
第十四届蓝桥杯青少年创意编程大赛C++选拔赛真题
一、题目要求
1、编程实现
有N(4<N<100)名同学站成一队,已知每名同学的身高 (单位: 厘米),请比较该队中任意相邻两名同学的身高差(取正值),并输出最大的身高差。
例如: N=8,8名同学的身高分别是 151、120、144、182、160、158、147、161。相邻两名同学的身高差依次是31、24、38、22、2、11、14,其中最大身高差是 38。
2、输入输出
输入描述:第一行输入一个正整数 N(4N<100),表示站队的同学人数
第二行输入N个正整数(80<正整数<220),表示队列中学生的身高(单位:厘米),相邻两个正整数之间用一个空格隔开
输出描述:输出一个非负整数,表示相邻两名同学中最大身高差。
输入样例:
8
151 120 144 182 160 158 147 161
输出样例:
38
二、算法分析
- 从给定题目的初步分析可以看出,先获取数量的个数
- 然后逐个输入对应的数字,可以用数组存放
- 接着可以遍历对应的每个数字,将后一个数字减去前一个数字,比较每次差的最大值
- 最后输出最大的插值即可
三、程序编写
#include<iostream>
using namespace std;
int a[102];
int main()
{int n,res = 0;cin >> n;for(int i = 1;i <= n;i++){cin >> a[i];}for(int i = 1; i < n;i++){int t = a[i+1] - a[i];if(t > res){res = t;}}cout << res << endl;return 0;
}
四、程序说明
- 首先需要导入输入输出流头文件
- 然后是引入std命名空间中的所有成员到当前的程序中,这样在当前的程序中就可以直接使用 std 命名空间中的所有成员,而不需要使用的时候在成员前面加上(std::)前缀
- 首先,代码定义了一个大小为102的整型数组a和一个整型变量res,用来存储最大差值
- 接着声明程序的入口,也就是主函数(主函数在一个程序中只允许出现一次)
- 然后,读取一个整数n作为数组a的长度,并使用for循环从1到n依次读入数组a的元素
- 接下来,使用另一个for循环从1到n-1遍历数组a中的元素,计算相邻两个元素的差值
- 并将差值与res比较,如果差值大于res,则更新res的值
- 最后利用输出流对象cout,输出res的值
- 最后返回0,程序结束
本文作者:小兔子编程 作者首页:https://blog.csdn.net/frank2102
五、运行结果
7
You are too young!
六、考点分析
难度级别:一般,这题相对而言难度不大,具体主要考查如下:
- 充分掌握变量的定义和使用
- 掌握一维数组的使用
- 学会输入流对象cin的使用,从键盘读入相应的数据
- 学会for循环的使用,在确定循环次数的时候推荐使用学会
- 学会while循环的使用,在不确定循环次数的时候推荐使用
- 学会if条件判断语句的使用,满足一定条件才能执行后面的语句
- 学会if...else...双分支语句的使用,条件满足执行一种处理,不满足执行另一种处理
- 掌握输出流对象cout的使用,与流插入运算符 << 结合使用将对象输出到终端显示
- 学会分析题目,算法分析,将复杂问题模块化,简单化,从中找到相应的解题思路
- 充分掌握变量定义和使用、分支语句、循环语句和数组的使用及输入输出的用法
PS:方式方法有多种,小朋友们只要能够达到题目要求即可!
七、推荐资料
- 所有考级比赛学习相关资料合集【推荐收藏】
这篇关于【蓝桥杯选拔赛真题47】C++相邻身高差 第十四届蓝桥杯青少年创意编程大赛 算法思维 C++编程选拔赛真题解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!