neuq oj 1038: 谭浩强C语言(第三版)习题4.8 C语言

疑问:保留两位小数,但不进行四舍五入,如何表示?若需要四舍五入又需如何表示?区别?待解决。

1038: 谭浩强C语言(第三版)习题4.8

时间限制: 1 Sec   内存限制: 128 MB
提交: 600   解决: 60
[ 提交][ 状态][ 讨论版]

题目描述

设圆半径r,圆柱高h 求圆周长C1、圆面积Sa、圆球表面积Sb、圆球体积Va、圆柱体积Vb。 用scanf输入数据,输出计算结果,输出时要求文字说明,取小数点后两位数字。请编程序。 PI=3.14

输入

两个浮点数,r和h

输出

圆周长C1、圆面积Sa、圆球表面积Sb、圆球体积Va、圆柱体积Vb。 保留两位小数,每个结果后换行。

样例输入

1.5 3

样例输出

C1=9.42
Sa=7.06
Sb=28.26
Va=14.13
Vb=21.19

代码

#include
int main()
{
	float r,h,C1,Sa,Sb,Va,Vb;
	scanf("%f%f",&r,&h);
	C1=2*3.14*r;
	Sa=3.14*r*r;
        Sb=4*3.14*r*r;
	Va=4*3.14*r*r*r/3;
	Vb=h*3.14*r*r;
	printf("C1=%.2f\n",C1);
	printf("Sa=%.2f\n",Sa-0.01);//此处有疑问:7.07?7.06?
	printf("Sb=%.2f\n",Sb);
	printf("Va=%.2f\n",Va);
	printf("Vb=%.2f\n",Vb);//21.195。。。。此处保留两位小数后为21.19
	return 0;

}

本题关键在于小数结果的处理。


printf用法:

type的 字符用于规定输出数据的类型,含义如下:
字符 对应数据类型 含义
d / i int 接受整数值并将它表示为有符号的十进制整数,i是老式写法
o unsigned int 无符号8进制整数(不输出前缀0)
u
unsigned int 无符号10进制整数
x / X
unsigned int 无符号16进制整数,x对应的是abcdef,X对应的是ABCDEF(不输出前缀0x)
f(lf)
float(double) 单精度浮点数用f,双精度浮点数用lf(尤其scanf不能混用)
e / E
double 科学计数法表示的数,此处"e"的大小写代表在输出时用的“e”的大小写
g / G
double 使用以上两种中最短的形式,大小写的使用同%e和%E
c
char 字符型。可以把输入的数字按照ASCII码相应转换为对应的字符
s / S
char * / wchar_t * 字符串。输出字符串中的字符直至字符串中的空字符(字符串以'\0‘结尾,这个'\0'即空字符)
p
void * 以16进制形式输出指针
n int * 到此字符之前为止,一共输出的字符个数,不输出文本
%
无输入
不进行转换,输出字符‘%’(百分号)本身
m 打印errno值对应的出错内容,(例: printf("%m\n"); )
注:%g、%G在小数点位数四位或指数大于等于精度时用%e、%E,否则用%f。

结果保留两位小数,四舍五入:

可以在输出的时候限制小数点位数。
1、当输出单精度浮点型float变量f时,可以用printf("%.2f", f);来使输出结果保留两位有效数字。

其中.2就是代表保留两位,如果要保留三位就是%.3f。用%.0f就是只输出整数。
2、如果是双精度浮点数double,就需要用%.2lf来使输出结果保留2位小数。

结果采用科学计数法:

%m.ne和%-m.ne:此处n指数据的数字部分的小数位数,m表示整个输出数据所占的宽度。


非常好的相关博客:

标准C I/O

http://www.cnblogs.com/minotmin/archive/2013/09/14/3320698.html

printf()格式化输出详解

http://www.cppblog.com/haosola/archive/2014/04/08/206503.html



你可能感兴趣的:(C++)