程序设计实习MOOC / 程序设计与算法(一)第二周测验(2018春季)-LMLPHP

程序设计实习MOOC / 程序设计与算法(一)第二周测验(2018春季)-LMLPHP

程序设计实习MOOC / 程序设计与算法(一)第二周测验(2018春季)-LMLPHP

程序设计实习MOOC / 程序设计与算法(一)第二周测验(2018春季)-LMLPHP

编程题:

1:对齐输出

总时间限制: 
1000ms

内存限制: 
65536kB
描述

读入三个整数,按每个整数占8个字符的宽度,右对齐输出它们。

输入
只有一行,包含三个整数,整数之间以一个空格分开。
输出
只有一行,按照格式要求依次输出三个整数,之间以一个空格分开。
样例输入
123456789 0 -1
样例输出
123456789        0       -1

答案:

#include <iostream>
using namespace std;
int main()
{
int i,j,k;
scanf(" %d %d %d",&i,&j,&k);
printf("%8d %8d %8d\n",i,j,k);
return 0;
}

2:输出保留12位小数的浮点数:

总时间限制: 
1000ms

内存限制: 
65536kB
描述

读入一个双精度浮点数,保留12位小数,输出这个浮点数。

输入
只有一行,一个双精度浮点数。
输出
也只有一行,保留12位小数的浮点数。
样例输入
3.1415926535798932
样例输出
3.141592653580

答案:

#include <iostream>
using namespace std;
int main()
{
double a;
scanf("%lf",&a);
printf("%.12lf\n",a);
return 0;

3:空格分隔输出

总时间限制: 
1000ms

内存限制: 
65536kB
描述

读入一个字符,一个整数,一个单精度浮点数,一个双精度浮点数,然后按顺序输出它们,并且要求在他们之间用一个空格分隔。输出浮点数时保留6位小数。

输入
共有四行:
第一行是一个字符;
第二行是一个整数;
第三行是一个单精度浮点数;
第四行是一个双精度浮点数。
输出
输出字符、整数、单精度浮点数和双精度浮点数,之间用空格分隔。
样例输入
a
12
2.3
3.2
样例输出
a 12 2.300000 3.200000

答案:  

#include <iostream>
using namespace std;
int main()
{
char a;
int b;
float c;
double d;
scanf("%c %d %f %lf",&a,&b,&c,&d);
printf("%c %d %.6lf %.6lf\n",a,b,c,d);
return 0;

4:计算球的体积

总时间限制: 
1000ms

内存限制: 
65536kB
描述

对于半径为r的球,其体积的计算公式为V=4/3*πr,这里取π= 3.14。

现给定r,求V。

输入
输入为一个不超过100的非负实数,即球半径,类型为double。
输出
输出一个实数,即球的体积,保留到小数点后2位。
样例输入
4
样例输出
267.95

答案:

#include <iostream>
using namespace std;
int main()
{
double r, v;
scanf("%lf",&r);
v = 4.0 / 3.0 * 3.14 * r * r * r;
printf("%.2lf\n", v);
return 0;

5:大象喝水

总时间限制: 
1000ms

内存限制: 
65536kB
描述

一只大象口渴了,要喝20升水才能解渴,但现在只有一个深h厘米,底面半径为r厘米的小圆桶(h和r都是整数)。问大象至少要喝多少桶水才会解渴。

输入
输入有一行:包行两个整数,以一个空格分开,分别表示小圆桶的深h和底面半径r,单位都是厘米。
输出
输出一行,包含一个整数,表示大象至少要喝水的桶数。
样例输入
23 11
样例输出
3
提示
如果一个圆桶的深为h厘米,底面半径为r厘米,那么它最多能装Pi * r * r * h立方厘米的水。(设Pi=3.14159) 
1升 = 1000毫升
1毫升 = 1 立方厘米
答案:
#include <iostream>
using namespace std;
#define PI 3.14159
#define SUM 20000
int main()
{
int h,r,n;
double total;
scanf("%d %d",&h,&r);
total=PI * r * r * h;
n = SUM / total;
if (n < SUM /total )
{
printf("%d",n+1);
}
else
{
printf("%d",n);
}
return 0;
}

  

  

  

  

  

1:对齐输出

04-30 23:08