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
    评论
可以通过栈来实现中缀表达式的计算。具体步骤如下: 1. 定义一个栈,用于存储数字和运算符。 2. 从左到右遍历中缀表达式中的每一个字符。 3. 如果当前字符是数字,则将其入栈。 4. 如果当前字符是运算符,则取出栈顶的两个数字进行运算,并将结果入栈。 5. 遍历完整个中缀表达式后,栈内只剩下一个元素,即为表达式的计算结果。 以下是一个示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <ctype.h> #include <string.h> #define STACK_SIZE 100 typedef struct { int data[STACK_SIZE]; int top; } Stack; void init(Stack *s) { s->top = -1; } void push(Stack *s, int value) { if (s->top >= STACK_SIZE - 1) { printf("Stack overflow"); exit(1); } s->data[++s->top] = value; } int pop(Stack *s) { if (s->top < 0) { printf("Stack underflow"); exit(1); } return s->data[s->top--]; } int main() { Stack s; char c; char expr[STACK_SIZE]; int len, i, num1, num2; init(&s); printf("Enter an infix expression: "); fgets(expr, STACK_SIZE, stdin); len = strlen(expr); for (i = 0; i < len; i++) { c = expr[i]; if (isdigit(c)) { push(&s, c - '0'); } else if (c == '+') { num2 = pop(&s); num1 = pop(&s); push(&s, num1 + num2); } else if (c == '-') { num2 = pop(&s); num1 = pop(&s); push(&s, num1 - num2); } else if (c == '*') { num2 = pop(&s); num1 = pop(&s); push(&s, num1 * num2); } else if (c == '/') { num2 = pop(&s); num1 = pop(&s); push(&s, num1 / num2); } } printf("Result: %d", pop(&s)); return 0; } ``` 注意,此代码仅适用于只包含加减乘除的中缀表达式。对于包含其他运算符的表达式,需要进行相应修改。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值