第九周项目四一元一次方程
2013-06-03 08:22
260 查看
/* * 程序的版权和版本声明部分: * Copyright (c) 2013, 烟台大学计算机学院 * All rights reserved. * 文件名称:test.cpp * 作 者:李果 * 完成日期:2013 年 5月 22日 * 版 本 号:v1.0 * 对任务及求解方法的描述部分: * 输入描述:无 * 问题描述: * 程序输出:“” * 问题分析:略 * 算法设计:略 */ #include <iostream> using namespace std; class CEquation { private: double a; // 未知数系数 double b; // 常数项 char unknown; // 未知数的符号 public: CEquation(double aa=0,double bb=0); friend istream &operator >> (istream &in,CEquation &e); friend ostream &operator << (ostream &out,CEquation e); double Solve(); char getUnknown(); }; CEquation::CEquation(double aa,double bb):a(aa),b(bb){} // 输入方程 istream &operator >> (istream &in,CEquation &e) { //3x-8=0; char x1,x2,x3,x4; while(1) { cin>>e.a>>x1>>x2>>e.b>>x3>>x4; if (x1>='a' && x1<='z') if ((x2=='+' || x2=='-') && x3=='=' && x4=='0') break; cout<<"输入错误,请重新输入!"<<endl; } if (x2=='-') e.b=-e.b; e.unknown=x1; return cin; } // 输出方程 ostream &operator << (ostream &out,CEquation e) { cout<<e.a<<e.unknown; if (e.b>=0) cout<<"+"; cout<<e.b<<"=0"<<endl; return out; } // 求解 double CEquation::Solve() { double x; if (a==0) { if (b==0) cout<<"任意一个实数均为方程的解。"<<endl; else cout<<"方程无解。"<<endl; return 0; } x=-b/a; return x; } char CEquation::getUnknown() { return unknown; } int main() { CEquation e; cout<<"请输入一元一次方程(输入格式:3x-8=0):"; cin>>e; cout<<"方程为:"<<e; cout<<"方程的解为:"<<e.getUnknown()<<"="<<e.Solve()<<endl; e.Solve(); return 0; }
相关文章推荐