乘法
用计算一元二次方程表示乘法的例子
/* 求方程的根: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位用来表示数值
整型数转换成实型数过程中,就是将数值部分写入实型数小数部分的数值中,指数则没有。
实型数运算规则
实型数在计算机内部都按指数形式存放
实型数在运算器中都按双精度计算
内存的存储精度取决于对变量的定义
数的有效位限制在最后输出时是按照存储结构和输出格式确定的
实际运算中,实型数表示范围较大,但是计算过程中值可能出现偏差,整型数表示范围较小,但是计算过程值是可控的。