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

   更新日期:2024.05.12
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);//四舍五入

第一种是利用系统默认的转换,即将小数部分截去,仅保留整数部分,如3.6转换为3,-5.68转换为5。
第二种是强制类型转换,效果与第一种相同,如(int)(-6.666)为-6。
如有其他特殊要求,则需要编程解决。

c语言中没有四舍五入,将浮点型转换成整形时,只保留小数点前面的数值

float ftemp;
不要后面的=0;因为一旦你分配给ftemp了值,它是无法通过键盘写入的方式赋给的,因为空间已经被占用。这不是a=b+c这样表达式的赋值。

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

随便输入一个数,然后回车,看结果

  • 14775568875 :C语言中如何实现将一个浮点数float转成int类型?
    邢宋研4709 :答:强制类型转换 比如:float a = 10.5;int b = (int)a;这样 就转换了,但是不推荐高精度转低精度 会丢失精度的 就像这个,a是10.5 转换后变成10了小了太多
  • 14775568875 :C语言中float型转换成int型是什么规则
    邢宋研4709 :答:} for(i2=0;i2<14;i2++){ printf("P[floatp]=%f\r\n",P[i2]);//打印出P数组的每一个元素值,以float型显示 } } 好像VC++6.0运行的结果只有强制转换有用,不知道是不是我写的语句有问题 ...
  • 14775568875 :c语言中的取整函数int语句怎么用?
    邢宋研4709 :答:这个操作并不是通过函数实现的,而是C语言的强制类型转换。强制浮点数转换为整数的规则为,只取浮点数的整数部分,无条件舍去小数部分。形式为 (int)float_number 于是 (int)1.3 的结果为1。(int)2.9999的结果为2。另...
  • 14775568875 :C语言浮点转整型
    邢宋研4709 :答:如果直接(long)x 相当于是取整的运算。只有 +0.5以后才是真正意义上的四舍五入。比如 原来是 5.1—(5.1+0.5)取整=5 原来是 5.6—(5.6+0.5)取整=6 原来是 -5.1—(5.1-0.5)取整=-5 原来是 ...
  • 14775568875 :C语言中,float x 强制转换为int x的过程
    邢宋研4709 :答:C语言整型使用原码、反码、补码进行编码,而浮点型使用IEEE754进行编码,所以强制转换基本上是没有任何意思的,因为编码格式不一样。正确的作法是使用c语言标准库中的floor和ceil函数来进行向下或者向上取整。比如:#include <...
  • 14775568875 :C语言:浮点数变为整数的一个疑惑?
    邢宋研4709 :答:因为你的a做了显式转换也还是有浮点数的形式的,但值确实是变成3了,关键在于双精度浮点数和整型数的差别和printf函数采用的栈输出结构;浮点型的位数比整型高,所以a输入进去以后,有效位数较双精度浮点数较小,因此存在着...
  • 14775568875 :C语言浮点转整型
    邢宋研4709 :答:如果直接(long)x 相当于是取整的运算。只有 +0.5以后才是真正意义上的四舍五入。比如 原来是 5.1—(5.1+0.5)取整=5 原来是 5.6—(5.6+0.5)取整=6 原来是 -5.1—(5.1-0.5)取整=-5 原来是 ...
  • 14775568875 :C语言数据类型的转换
    邢宋研4709 :答:在进行运算时,以表达式中最长类型为主,将其他类型位据均转换成该类型,如:(1)若运算数中有double型或float型,则其他类型数据均转换成double类型进行运算。(2)若运算数中最长的类型为long型.则其他类型数均转换成long...
  • 14775568875 :C语言浮点型转整型
    邢宋研4709 :答:而ANSI C一般不会自动把float转换成double。有些程序已假定其中的float参数会被转换成double,为了保护大量这样的程序,所有printf()函数的float参数还是被自动转换成double型。只要你输入的数载float的范围内,那么转化为double型...
  • 14775568875 :大菜鸟提问:将浮点数转换为整数(C程序)谢谢!
    邢宋研4709 :答:include <stdio.h> main(){ float a,m;int t;scanf("%f",&a);if (a>0){t=(int)a;m=(float)(t+0.5);if(a>=m){ t=t+1;} printf("%d",t);} else printf("error");} ...
  • 相关链接

    欢迎反馈与建议,请联系电邮
    2024 © 视觉网