c计算数学表达式

/*
 ============================================================================
 Name        : demo.c
 Author      : Johnson Z.
 Version     :
 Copyright   : Your copyright notice
 Description : Hello World in C, Ansi-style
 ============================================================================
 */

#include <stdio.h>
#include <stdlib.h>

struct node {
	double radix;
	char operator;
	struct node* next;
};

int npower(int n) {
	int val = 1;
	if (n == 0) return 1;
	while (n-- > 0)
		val *= 10;
	return val;
}

double get_value(char* str, int len) {
	double val = 0;
	char c = *str;
	len--;
	while (c != 0) {
		int i = c - 48; // '0' == 48
		val += i * npower(len--);
		str++;
		c = *str;
	}

	return val;
}

void compute(char* input) {
	printf("input=%s\n", input);
	struct node* head = NULL;
	struct node* ptr = NULL;
	struct node* pre = NULL;
	char* buf = (char*) calloc(1, 13);

	for (char c = *input; c != 0; c = *input) {
		pre = ptr;
		ptr = (struct node*) calloc(1, sizeof(struct node));
		ptr->operator = 0;
		ptr->next = NULL;

		if (NULL != pre) {
			pre->next = ptr;
		}

		if (NULL == head) {
			head = ptr;
		}

		if (c == '+' || c == '-' || c == '*' || c == '/') {
			ptr->operator = c;
			input++;
			continue;
		}

		int idx = 0;
		while (c != '+' && c != '-' && c != '*' && c != '/' && c != 0) {
			buf[idx++] = c;
			input++;
			c = *input;
		}
		buf[idx] = 0;

		ptr->radix = get_value(buf, idx);
	}

	pre = head;
	ptr = pre->next;
	while (ptr != NULL ) {
		if (ptr->operator && ptr->operator != '+' && ptr->operator != '-') {
			if (ptr->operator == '*') {
				pre->radix = (pre->radix) * (ptr->next->radix);
			}

			if (ptr->operator == '/') {
				pre->radix = pre->radix / ptr->next->radix;
			}

			pre->next = ptr->next->next;
			pre->operator = 0;
			ptr = pre->next;
			continue;
		}
		pre = ptr;
		ptr = ptr->next;
	}

	pre = head;
	ptr = pre->next;
	while (ptr != NULL ) {
		if (ptr->operator && ptr->operator != '*' && ptr->operator != '/') {
			if (ptr->operator == '+') {
				pre->radix = (pre->radix) + (ptr->next->radix);
			}

			if (ptr->operator == '-') {
				pre->radix = pre->radix - ptr->next->radix;
			}

			pre->next = ptr->next->next;
			pre->operator = 0;
			ptr = pre->next;
			continue;
		}
		pre = ptr;
		ptr = ptr->next;
	}

	printf("value=%.2f\n", pre->radix);

	ptr = head;
	while (ptr) {
		pre = ptr;
		ptr = ptr->next;
		free(pre);
	}
	free(buf);
}

int main(void) {
	compute("100/2-200/2+100*1+200*1-10/3");
	return EXIT_SUCCESS;
}



  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的C代码,用于计算数学表达式的值: ```c #include <stdio.h> #include <stdlib.h> #include <math.h> #define MAX_EXPR_LEN 100 int main() { char expr[MAX_EXPR_LEN]; printf("请输入数学表达式:"); fgets(expr, MAX_EXPR_LEN, stdin); int i = 0; double num_stack[MAX_EXPR_LEN]; char op_stack[MAX_EXPR_LEN]; int num_top = -1; int op_top = -1; while (expr[i] != '\n' && expr[i] != '\0') { if (isdigit(expr[i])) { double num = 0; while (isdigit(expr[i])) { num = num * 10 + (expr[i] - '0'); i++; } if (expr[i] == '.') { i++; double frac = 0.1; while (isdigit(expr[i])) { num += frac * (expr[i] - '0'); frac /= 10; i++; } } num_stack[++num_top] = num; } else if (expr[i] == '(') { op_stack[++op_top] = expr[i]; i++; } else if (expr[i] == '+' || expr[i] == '-' || expr[i] == '*' || expr[i] == '/') { while (op_top >= 0 && op_stack[op_top] != '(' && ( (expr[i] == '+' || expr[i] == '-') && (op_stack[op_top] == '+' || op_stack[op_top] == '-' || op_stack[op_top] == '*' || op_stack[op_top] == '/') || (expr[i] == '*' || expr[i] == '/') && (op_stack[op_top] == '*' || op_stack[op_top] == '/') )) { double b = num_stack[num_top--]; double a = num_stack[num_top--]; char op = op_stack[op_top--]; switch (op) { case '+': num_stack[++num_top] = a + b; break; case '-': num_stack[++num_top] = a - b; break; case '*': num_stack[++num_top] = a * b; break; case '/': num_stack[++num_top] = a / b; break; } } op_stack[++op_top] = expr[i]; i++; } else if (expr[i] == ')') { while (op_stack[op_top] != '(') { double b = num_stack[num_top--]; double a = num_stack[num_top--]; char op = op_stack[op_top--]; switch (op) { case '+': num_stack[++num_top] = a + b; break; case '-': num_stack[++num_top] = a - b; break; case '*': num_stack[++num_top] = a * b; break; case '/': num_stack[++num_top] = a / b; break; } } op_top--; i++; } else { i++; } } while (op_top >= 0) { double b = num_stack[num_top--]; double a = num_stack[num_top--]; char op = op_stack[op_top--]; switch (op) { case '+': num_stack[++num_top] = a + b; break; case '-': num_stack[++num_top] = a - b; break; case '*': num_stack[++num_top] = a * b; break; case '/': num_stack[++num_top] = a / b; break; } } printf("结果:%.2f\n", num_stack[num_top]); return 0; } ``` 该代码使用了两个栈,一个存储数字,一个存储操作符,依次处理表达式中的每个字符,并根据规则进行计算。需要注意的是,该代码仅支持四则运算和小数点,不支持其他高级运算符和函数。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值