⑴ 整型和浮点型数据1 2.123等于多少
结果肯定是浮点型数据。因为浮点型数据属于所谓“高类型”(比整型高),而整型数专据属于“低属类型”。计算机语言中数据类型的转换有自动和强制两种方式,浮点型数据加整型数据符合自动转换规范。自动转换规则是“低类型”数据向“向类型”数据看齐,即一个浮点数加一个整型数,是要将整型数自动变为浮点数来求和的,结果当然是浮点型数据……
⑵ 整型和浮点型相减的问题
printf("%lf",double(12)-int(12));
有结果,是12.0.
double的12就是12.0
解释为什么是死循环-
浮点数是二进制存储,而精确的浮点二进制存储为,整数是2的+n次方的算术和,小数是2的-n次方的算术和.例如0.5、0.25、0.125此类小数可以精确表示,而诸如0.1、0.17这类小数就有误差,具体体现在浮点数的位数波动,实际的存储值可能编程了0.1000125、0.17000025之类.
double和int的算术运算向double对齐,所以r-int(r)是一个浮点数,显然当r不是精确二进制小数时,表达式的结果含有小数位,不为double(0),会循环下去.当r较小的时候,表达式的结果仅为一个较小的纯小数,当r增大到超过int的极值+2147483648后,(int)r会被截断,r-int(r)从纯小数陡增为极大的浮点数.死循环
你可以尝试在你的设计中,把r=4.2356改成r=4.125,则不为死循环,可以得到预期结果
或者你改成r-(int)r>0.0001,这样就只有当r的小数位超过10位的截断问题.比如r=4.2356时还是无法计算,因为实际存储位数超过10位,(int)r被截断后表达式变成很大的浮点数,死循环.
我提供如下算法.判断标准比较类似>0.0001这种精确度的折中法,每次*10后判断个位,连续3次个位为0则退出循环
#include "stdio.h"
main()
{
double r;scanf("%lf",&r);
double r1=(int)r;int m=0,n=0,g;
//g表示个位,r1结合r计算个位
while(1)
{
r*=10;
r1*=10;
g=int(r-r1);
//这样提取个位比g=int(r)%10可表达的r大,后者r过大会被截断
r1+=g;
m++;
if(!g)n++;
else n=0;
if(n==3)break;
}
printf("%lf %d",r1/1000,m-3);
}
要注意的是,结果的r1/1000和m-3中只有m有效,表示浮点数实际存储的小数位,而r1在增大的过程中,可能由于位数过长而被截断,成为误差值.例如r=4.2356时,就只有m有效
⑶ c语言中整型和浮点型混合运算的结果是什么类型
c语言中整型和浮点型混合运算的结果为double型(双精度浮点类型)。
c语言中如果一个运算符两边的运算数类型不同,先要将其转换为相同的类型,即较低类型转换为较高类型,然后再参加运算,转换规则:float(浮点型)转化为double(双精度浮点类型)、int(整型)转为unsigned(无符号整型)转为long(长整型)转为(双精度浮点类型)。
因此,c语言中整型和浮点型混合运算,只能是整型和浮点型同时强制转换为相同的double型(双精度浮点类型)。如两个float型数参加运算,虽然它们类型相同,但仍要先转成double型再进行运算,结果亦为double型。
(3)整形和浮点型扩展阅读:
在C语言中,自动类型转换遵循以下规则:
1、若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
2、转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。若两种类型的字节数不同,转换成字节数高的类型。若两种类型的字节数相同,且一种有符号,一种无符号,则转换成无符号类型。
3、所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
4、char型和short型参与运算时,必须先转换成int型。
5、在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度比左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。
⑷ c语言中整形和浮点型是什么意思
整型就是整数 如:1,2,3,4
浮点型就是有小数点的 如:0.34,1.8 啥的 浮点型有单精度float 和双精度double
⑸ 整型除以浮点型是什么型
浮点型精度高于整形,因此整形数先自动被转换成浮点型,再进行除法运算,最终结果也为浮点型
⑹ C语言中整型,字符型,浮点型,和双精度浮点型,详解
整型,计算机中的一个基本的专业术语,指没有小数部分的数据。整型可以用十进制,十六进制或八进制符号指定,前面可以加上可选的符号(- 或者 +)。包括整型常量和整型变量,整型变量又包括短整型、基本整型、长整型,它们都分为有符号和无符号两种版本,是一种智能的计算方式。
字符型量包括字符常量和字符变量。字符串常量由一对双引号括起的字符序列。字符变量的取值是字符常量,即单个字符。字符变量的类型说明符是char。字符变量类型说明的格式和书写规则都与整型变量相同。
浮点型利用指数使小数点的位置可以根据需要而上下浮动,从而可以灵活地表达更大范围的实数。
双精度浮点型,此数据类型与单精度数据类型(float)相似,但精确度比float高,编译时所占的内存空间依不同的编译器而有所不同,是double float数据类型,C/C++中表示实型变量的一种变量类型。
(6)整形和浮点型扩展阅读
双精度浮点型类型数值可转换到其他类型的整数或浮点数,反之亦然。双精度浮点型常量的最后一个字符可加上“d”或“D”。其存储格式与浮点型类似,最高位为符号位,次高11位为指数位,其次52位为尾数。
双精度型就是双精度浮点型,同数值型比,它能提供更高的数值精度,采用固定存储长度的浮点数形式,每个双精度浮点型数据占8个字节。与数值型数据不同,它的小数点位置是由输入的数据值来决定的,并且只能用于表中的字段。
⑺ 整型数据和实型数据的区别
整型常量和实型常量
1.整型常量
在 C
语言中,整型常量分为十进制整型常量、八进制整型常量和十六进制整型常量三
种表示形式。
(1)十进制整型常量
这种常量只能出现 0~9
的数字,且可带正、负号。例如:
0 1 364 28 -34
第 2 章 基本数据类型 •29•
(2)八进制整型常量
这种常量是以数字
0 开头的八进制数字串。其中数字为 0~7。例如:
0111(十进制 73) 011(十进制 9) 0123(十进制
83)
(3)十六进制整型常量
这种常量是以 0x或 0X开头的十六进制数字串。其中每个数字可以是 0~9、a~f或 A~
F
中的数字或英文字母。例如:
0x11(十进制 17) 0Xa5(十进制 165) 0x5a(十进制
90)
以上三种进制的常量可用于不同的场合。大多数场合中采用十进制常量,但当编写系
统程序时,如表示地址等,常用八进制或十六进制常量。
一般情况下,编译程序会根据常量的数值分辨出常量是
int 还是 long int 类型。但是有
些场合需要明确地指出它是否属于 long int 类型。此时,可以在整型常量后附加一个字母 l
或 L
强制它为 long int 类型。例如,4126l,78l,5L
等。
2.实型常量
实型常量有两种表示形式:一种是十进制小数形式,另一种是指数形式。
(1)十进制小数形式
十进制小数形式为包含一个小数点的十进制数字串。
此类实型常量小数点前或后可以没有数字,但不能同时没有数字。例如:
3.14159,
.89, 56.0, 78., -3.0,
0.0
(2)指数形式
指数形式的格式由两部分组成:十进制小数形式或十进制整型常量部分和指数部分。
其中指数部分是在 e 或
E(相当于数学中幂底数 10)后跟整数阶码(即可带符号的整数指
数)。例如:
1e15 //表示数值 1×10
15
0.35e+1 //表示数值 0.35×10
1
78e-1 //表示数值 78×10
-1
⑻ 浮点型和整型相加,结果是什么类型
浮点型运算的时候不是一律先变成双精度型吗?
⑼ 整型变量和浮点变量的意思和区别
整型是整来数的一部分所组成的集自合;浮点型是实数中的一部分组成的集合,带小数位。
整型变量就是存放整数的变量,在Dos下,范围是:-32668~32767;在Windows下,范围是-2的32次幂到2的32次幂-1
浮点变量:表示以浮点形式表示实数的变量,其中也规定了占用的空间量,字节数;以及表示的范围。
⑽ 整数和浮点数的区别
整数是指正整数、负整数和零,如-6、0、32 等。
浮点数是指带有有限位小数的有理数,如-10.8、0.00、25.01 等。回
整数答既可以是整数,也可以是浮点数,例如255 是整数,而255.0 则是浮点数。
整数运算,得到的结果是一个整数,并且计算结果中的小数部分将被忽略。例如:用整数运算时,100÷3=33。
浮点运算,得到的结果是一个浮点数,计算结果中的小数部分将保留下来。