1.求平均年龄【1.5编程基础之循环控制01】
班上有学生若干名,给出每名学生的年龄(整数),求班上所有学生的平均年龄,保留到小数点后两位。
输入:
第一行有一个整数n(1<= n <= 100),表示学生的人数。其后n行每行有1个整数,表示每个学生的年龄,取值为15到25。
输出:
输出一行,该行包含一个浮点数,为要求的平均年龄,保留到小数点后两位。
样例输入:
2
18
17
样例输出:
17.50
#include<iostream>
using namespace std;
int main()
{
int n,m; //学生人数 顺序输入学生年龄
cin>>n;
double sum=0; //全部学生的年龄和
for(int i=1;i<=n;i++)
{
cin>>m; //从第一个学生的年龄开始输入
sum+=m; //年龄和
}
printf("%.2lf\n",sum/n);
return 0;
}
2.均值【1.5编程基础之循环控制02】
给出一组样本数据,包含n个浮点数,计算其均值,精确到小数点后4位。
输入:
输入有两行,第一行包含一个整数n(n小于100),代表样本容量;第二行包含n个绝对值不超过1000的浮点数,代表各个样本数据。
输出:
输出一行,包含一个浮点数,表示均值,精确到小数点后4位。
样例输入:
2
1.0 3.0
样例输出:
2.0000
#include<iostream>
#include<cstdio>
using namespace std;
int main()
{
int n;
float m,sum=0;
cin>>n;
for(int i=0;i<n;i++) //循环语句与i无关时一般i=0
{
cin>>m;
sum+=m;
}
printf("%.4f\n",sum/n);
return 0;
}
3.求整数的和与均值【1.5编程基础之循环控制03】
读入n(1<=n<=10000)个整数,求它们的和与均值。
输入:
输入第一行是一个整数n,表示有n个整数。
第2~n+1行每行包含1个整数。每个整数的绝对值均不超过10000。
输出:
输出一行,先输出和,再输出平均值(保留到小数点后5位),两个数间用单个空格分隔。
样例输入:
4
344
222
343
222
样例输出:
1131 282.75000
#include<iostream>
#include<iomanip>
using namespace std;
int main()
{
int n,m;
cin>>n;
int sum=0;
for(int i=1;i<=n;i++)
{
cin>>m;
sum+=m;
}
//cout<<sum<<" "<<fixed<<setprecision(5)<<avg<<endl;
//printf("%.0f\n",sum);
printf("%d %.5lf",sum,(double)sum/n);
return 0;
}
4.最高的分数【1.5编程基础之循环控制04】
孙老师讲授的《计算概论》这门课期中考试刚刚结束,他想知道考试中取得的最高分数。因为人数比较多,他觉得这件事情交给计算机来做比较方便。你能帮孙老师解决这个问题吗?
输入:
输入两行,第一行为整数n(1 <= n < 100),表示参加这次考试的人数.第二行是这n个学生的成绩,相邻两个数之间用单个空格隔开。所有成绩均为0到100之间的整数。
输出:
输出一个整数,即最高的成绩。
样例输入:
5
85 78 90 99 60
样例输出:
99
#include<iostream>
using namespace std;
int main()
{
int n,i; //学生人数
int a,max; //学生分数
max=a;
cin>>n>>a;
for(i=2;i<=n;i++)
{
cin>>a;
if(a>max)
max=a;
}
cout<<max<<endl;
return 0;
}
5.最大跨度值【1.5编程基础之循环控制05】
给定一个长度为n的非负整数序列,请计算序列的最大跨度值(最大跨度值 = 最大值减去最小值)。
输入:
一共2行,第一行为序列的个数n(1 <= n <= 1000),第二行为序列的n个不超过1000的非负整数,整数之间以一个空格分隔。
输出:
输出一行,表示序列的最大跨度值。
样例输入:
6
3 0 8 7 5 9
样例输出:
9
#include<iostream>
#include<cmath>
#include<cstdio>
using namespace std;
int main()
{
int m,n,max=0,min=1000;
int i,j;
cin>>n;
for(i=1;i<=n;i++)
{
cin>>m;
if(max<m)
max=m;
if(min>m)
min=m;
}
j=max-min;
cout<<j<<endl;
return 0;
}
6.奥运奖牌计数【1.5编程基础之循环控制06】
2008年北京奥运会,A国的运动员参与了n天的决赛项目(1≤n≤17)。现在要统计一下A国所获得的金、银、铜牌数目及总奖牌数。输入第1行是A国参与决赛项目的天数n,其后n行,每一行是该国某一天获得的金、银、铜牌数目。输出4个整数,为A国所获得的金、银、铜牌总数及总奖牌数。
输入:
输入n+1行,第1行是A国参与决赛项目的天数n,其后n行,每一行是该国某一天获得的金、银、铜牌数目,以一个空格分开。
输出:
输出1行,包括4个整数,为A国所获得的金、银、铜牌总数及总奖牌数,以一个空格分开。
样例输入:
3
1 0 3
3 1 0
0 3 0
样例输出:
4 4 3 11
#include<iostream>
using namespace std;
int main()
{
int n,i;
cin>>n;
int a,b,c,sum1=0,sum2=0,sum3=0,sum=0;
for(i=1;i<=n;i++)
{
cin>>a>>b>>c;
sum1+=a;
sum2+=b;
sum3+=c;
sum=sum1+sum2+sum3;
}
cout<<sum1<<" "<<sum2<<" "<<sum3<<" "<<sum