文章目录
01:与指定数字相同的数的个数
总时间限制: 1000ms 内存限制: 65536kB
描述
输出一个整数序列中与指定数字相同的数的个数。
输入
输入包含三行:第一行为N,表示整数序列的长度(N <= 100);第二行为N个整数,整数之间以一个空格分开;第三行包含一个整数,为指定的整数m。
输出
输出为N个数中与m相同的数的个数。
样例输入
3
2 3 2
2
样例输出
2
参考代码
#include<iostream>
using namespace std;
int main(){
int n, c=0, num;
cin >> n;
int m[n];// 定义数组
for(int i=0;i<n;i++){
// 将输入保存到数组中。
cin >> m[i];
}
cin >> num;
for(int i=0;i<n;i++){
//循环遍历数组
if(m[i]==num)c++;//如果相同 计数
}
cout << c <<endl;
return 0;
}
02:陶陶摘苹果
总时间限制: 1000ms 内存限制: 65536kB
描述
陶陶家的院子里有一棵苹果树,每到秋天树上就会结出10个苹果。苹果成熟的时候,陶陶就会跑去摘苹果。陶陶有个30厘米高的板凳,当她不能直接用手摘到苹果的时候,就会踩到板凳上再试试。现在已知10个苹果到地面的高度,以及陶陶把手伸直的时候能够达到的最大高度,请帮陶陶算一下她能够摘到的苹果的数目。假设她碰到苹果,苹果就会掉下来。
输入
包括两行数据。第一行包含10个100到200之间(包括100和200)的整数(以厘米为单位)分别表示10个苹果到地面的高度,两个相邻的整数之间用一个空格隔开。第二行只包括一个100到120之间(包含100和120)的整数(以厘米为单位),表示陶陶把手伸直的时候能够达到的最大高度。
输出
包括一行,这一行只包含一个整数,表示陶陶能够摘到的苹果的数目。
样例输入
100 200 150 140 129 134 167 198 200 111
110
样例输出
5
参考代码
#include<iostream>
using namespace std;
int main(){
const int b=30;//板凳高度
int a[10], h, count=0;
for(int i=0;i<10;i++){
cin >> a[i];//将输入保存到数组中
}
cin >> h;
for(int i=0;i<10;i++){
//循环遍历数据,根据条件进行计数
if(h+b>=a[i])count++;
}
cout << count << endl;
return 0;
}
03:计算书费
总时间限制: 1000ms 内存限制: 65536kB
描述
下面是一个图书的单价表:
计算概论 28.9 元/本
数据结构与算法 32.7 元/本
数字逻辑 45.6元/本
C++程序设计教程 78 元/本
人工智能 35 元/本
计算机体系结构 86.2 元/本
编译原理 27.8元/本
操作系统 43 元/本
计算机网络 56 元/本
JAVA程序设计 65 元/本
给定每种图书购买的数量,编程计算应付的总费用。
输入
输入一行,包含10个整数(大于等于0,小于等于100),分别表示购买的《计算概论》、《数据结构与算法》、《数字逻辑》、《C++程序设计教程》、《人工智能》、《计算机体系结构》、《编译原理》、《操作系统》、《计算机网络》、《JAVA程序设计》的数量(以本为单位)。每两个整数用一个空格分开。
输出
输出一行,包含一个浮点数f,表示应付的总费用。精确到小数点后一位。
样例输入
1 5 8 10 5 1 1 2 3 4
样例输出
2140.2
参考代码
#include<iostream>
#include<iomanip>
using namespace std;
int main(){
float b[10]={
28.9, 32.7, 45.6, 78, 35, 86.2, 27.8, 43, 56, 65},s=0;//数组中保存书的价格
int c;
for(int i=0;i<10;i++){
cin >> c;//输入数量
s+=b[i]*c;//计算总价
}
cout << fixed << setprecision(1) << s << endl;
return 0;
}
04:数组逆序重放
总时间限制: 1000ms 内存限制: 65536kB
描述
将一个数组中的值按逆序重新存放。例如,原来的顺序为8,6,5,4,1。要求改为1,4,5,6,8。
输入
输入为两行:第一行数组中元素的个数n(1<n<100),第二行是n个整数,每两个整数之间用空格分隔。
输出
输出为一行:输出逆序后数组的整数,每两个整数之间用空格分隔。
样例输入
5
8 6 5 4 1
样例输出
1 4 5 6 8
参考代码
#include<iostream>
#include<iomanip>
using namespace std;
int main(){
int n, m[100];
cin >> n;
for(int i=0;i<n;i++){
//将输入保存到数组中,索引值从0到n-1
cin >> m[i];
}
for(int i=n-1;i>=0;i--){
//遍历数组,从索引值n-1到0.实现逆序输出
cout << m[i] << ' ';
}
return 0;
}
05:年龄与疾病
总时间限制: 1000ms 内存限制: 65536kB
描述
某医院想统计一下某项疾病的获得与否与年龄是否有关,需要对以前的诊断记录进行整理,按照0-18、19-35、36-60、61以上(含61)四个年龄段统计的患病人数占总患病人数的比例。
输入
共2行,第一行为过往病人的数目n(0 < n <= 100),第二行为每个病人患病时的年龄。
输出
按照0-18、19-35、36-60、61以上(含61)四个年龄段输出该段患病人数占总患病人数的比例,以百分比的形式输出,精确到小数点后两位。每个年龄段占一行,共四行。
样例输入
10
1 11 21 31 41 51 61 71 81 91
样例输出
20.00%
20.00%
20.00%
40.00%
参考代码
#include<iostream>
#include<iomanip>
using namespace std;
int main(){
int a, n, r[4]={
0};
cin >> n;
for(int i=0;i<n;i++){
cin