欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

解只含加减的一元一次方程

程序员文章站 2024-03-17 20:47:40
...

解一元一次方程

在计算器上键入的一个一元一次方程中,只包含整数、小写字母及+、-、=这三个数学符号(当然,符号“─”既可作减号,也可作负号)。方程中并没有括号,也没有除号,方程中的字母表示未知数。输入一元一次方程, 将解方程的结果(精确至小数点后三位)输出至屏幕。

示例

输入:
解只含加减的一元一次方程
输出
解只含加减的一元一次方程
代码如下

#include"stdlib.h"
#include"iostream"
#include "iomanip"
#include"string"
using namespace std;
int main()
{
	string str;
	int index = 0;
	bool isLeft = true;
	int op, i = 0;
	double result = 0;
	int xMultiple = 0;
	char x;
	cin >> str;
	int len = str.length();
	while (i < str.length())
	{
		if (str[i] == '-' || str[i] == '+')
		{
			i++;
			index++;
		}
		//取操作数
		while (i < len && str[i] >= '0' && str[i] <= '9')
		{
			i++;
		}
		op = atoi(str.substr(index, i - index).c_str());
		if (i > 0 && (str[i - 1]< '0' || str[i - 1] > '9'))
		{
			op = 1;
		}
		if ((index > 0) && (str[index - 1] == '-'))
		{
			op *= -1;
		}
		//是未知数
		if (str[i] >= 'a' && str[i] <= 'z')
		{
			x = str[i];
			if (isLeft)
				xMultiple += op;
			else
				xMultiple -= op;
		}
		else
		{
			if (isLeft)
				result += op;
			else
				result -= op;
		}
		if (str[i] == '=')
		{
			isLeft = false;
		}
		i++;
		if (i < len && str[i] == '=')
		{
			isLeft = false;
			i++;
		}
		index = i;
	}
	cout << x << "=" << fixed << setprecision(3) << -1 * result / xMultiple;
	return 0;
}