C语言浮点型转换为整型怎么转换的?

例如floata=5.75(int)a求出来是5,为什么不是6?... 例如
float a=5.75
(int)a 求出来是5,为什么不是6?
展开
 我来答
程序猿3号
2013-05-20 · TA获得超过1811个赞
知道小有建树答主
回答量:1029
采纳率:33%
帮助的人:769万
展开全部
C语言有以下几种取整方法:
1、直接赋值给整数变量。如:
int i = 2.5; 或 i = (int) 2.5;
这种方法采用的是舍去小数部分,能用于你的问题。
2、C/C++中的整数除法运算符“/”本身就有取整功能(int / int),而下面介绍的取整函数返回值是double。整数除法对正数的取整是舍去小数部分,能用于你的问题。不过整数除法对负数的取整结果和使用的C编译器有关。
3、使用floor函数。floor(x)返回的是小于或等于x的最大整数。如:
floor(2.5) = 2
floor(-2.5) = -3
4、使用ceil函数。ceil(x)返回的是大于x的最小整数。如:
ceil(2.5) = 3
ceil(-2.5) = -2
floor()是向负无穷大舍入,floor(-2.5) = -3;ceil()是向正无穷大舍入,ceil(-2.5) = -2。floor函数能用于你的问题。
5、
int b = (int)a;//取整
int c = (int)(a+0.5);//四舍五入
xoaxa
2015-05-16 · TA获得超过8610个赞
知道大有可为答主
回答量:6415
采纳率:72%
帮助的人:3486万
展开全部
第一种是利用系统默认的转换,即将小数部分截去,仅保留整数部分,如3.6转换为3,-5.68转换为5。
第二种是强制类型转换,效果与第一种相同,如(int)(-6.666)为-6。
如有其他特殊要求,则需要编程解决。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
林小葱
2013-05-20 · 超过10用户采纳过TA的回答
知道答主
回答量:34
采纳率:0%
帮助的人:13.6万
展开全部
c语言中没有四舍五入,将浮点型转换成整形时,只保留小数点前面的数值
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
aaaqiutao
2013-05-21 · 超过42用户采纳过TA的回答
知道小有建树答主
回答量:136
采纳率:50%
帮助的人:84.6万
展开全部
float ftemp;
不要后面的=0;因为一旦你分配给ftemp了值,它是无法通过键盘写入的方式赋给的,因为空间已经被占用。这不是a=b+c这样表达式的赋值。

晕,难道要我把源代码给你你直接复制?
那就给你吧!
#include
void main()
{
float ftemp;
scanf("%f",&ftemp);
ftemp=ftemp*10;
printf("%f",ftemp);
getch();
}

随便输入一个数,然后回车,看结果
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式