C语言:乘除

乘法

用计算一元二次方程表示乘法的例子

/* 求方程的根:ax^2 + bx + c = 0 */
#include "math.h"
main()
{
	float a, b, c, d, x1, x2, q;
	printf("please input a, b, c\n");
	scanf("%f,%f,%f", &a, &b, &c);
	d = b * b - 4 * a * c;	// 验证方程b的平方大于4ac 
	q = sqrt(d);	// 求值的开平方 
	x1 = (-b + q) / (2 * a);
	x2 = (-b - q) / (2 * a);
	printf("d=%.2f, x1=%.2f, x2=%.2f\n", d, x1, x2);
}
 

除法

5 / 3    // 相除,值为1
5 % 3    // 取余,值为2

整数相除,结果只保留整数,小数部分丢失

实型数和整形数运算,会先将整形数转换成实型数,结果也会返回实型数

实型数存储规则

如值为单精度值,则在内存空间占4字节,其中3字节用来表示小数部分,1字节用来表示指数部分。

小数部分:使用一位来表示小数符号(正、负),用23位来表示小数的数值

指数部分:使用一位来表示指数符号(正、负),用7位来表示指数的值

整形数存储规则

整形数占用内存的2字节中,1位用来表示符号(正、负),15位用来表示数值

整型数转换成实型数过程中,就是将数值部分写入实型数小数部分的数值中,指数则没有。

实型数运算规则

实型数在计算机内部都按指数形式存放

实型数在运算器中都按双精度计算

内存的存储精度取决于对变量的定义

数的有效位限制在最后输出时是按照存储结构和输出格式确定的

 

实际运算中,实型数表示范围较大,但是计算过程中值可能出现偏差,整型数表示范围较小,但是计算过程值是可控的。

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值