多态的方法求定积分

#include <iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
using namespace std;
void menu1();
void menu2();
class FUN
{
public:
    virtual double operator()(double x) const=0;
    virtual ~FUN(){}
};
class Function1:public FUN
{
public:
    virtual double operator()(double x) const
    {
        return x;
    }
};
class Function2:public FUN
{
public:
    virtual double operator()(double x) const
    {
        return sin(x);
    }
};
class Function3:public FUN
{
    virtual double operator ()(double x) const
    {
        return exp(x);
    }
};
class Integration
{
public:
    virtual double operator()(double a,double b,double n) const=0;
    virtual ~Integration(){}
};
class Trapzt:public Integration
{
private:
    const FUN &f;
public:
    Trapzt(const FUN &f):f(f){}
    virtual double operator()(double a,double b,double n) const
    {
        double h=fabs(b-a)/n,s=f(a);
        int i;
        for(i=1;i<=n;i++)
            s+=2*f(a+i*h);
        s-=f(b);
        s=s*h/2;
        return s;
    }
};
class Trapzj:public Integration
{
private:
    const FUN &f;
public:
    Trapzj(const FUN &f):f(f){}
    virtual double operator()(double a,double b,double n) const
    {
        double h=fabs(b-a)/n,s=0;
        int i;
        for(i=0;i<n;i++)
            s+=f(a+i*h+h/2);
        s*=h;
        return s;
    }
};
class Trapzs:public Integration
{
private:
    const FUN &f;
public:
    Trapzs(const FUN &f):f(f){}
    virtual double operator()(double a,double b,double n) const
    {
        double h=fabs(b-a)/n,s=(f(a)+f(b))/2;
        int i;
        for(i=1;i<n;i++)
            s+=f(a+i*h);
        s*=h;
        return s;
    }
};
int main()
{
    Function1 f1;
    Function2 f2;
    Function3 f3;
    Trapzt t1(f1);
    Trapzt t2(f2);
    Trapzt t3(f3);
    Trapzj j1(f1);
    Trapzj j2(f2);
    Trapzj j3(f3);
    Trapzj s1(f1);
    Trapzj s2(f2);
    Trapzj s3(f3);
    while(1)
    {
        system("cls");
        menu1();
        cout<<"请输入你想要积分函数的序号:"<<endl;
        int k,l,a,b,flag=1;
        double n;
        char c;
        cin>>k;
        switch(k)
        {
            case 1:while(flag)
            {
                system("cls");
                cout<<"f(x)=x"<<endl;
                menu2();
                cin>>l;
                switch(l)
                {
                case 1:cout<<"梯形法: "<<endl;
                       cout<<"请输入积分上下线和要分的个数"<<endl;
                       cin>>a>>b>>n;
                       cout<<"积分得: "<<t1(a,b,n)<<endl;
                       c=getchar();
                       system("pause");
                       break;
                case 2:cout<<"矩形法: "<<endl;
                       cout<<"请输入积分上下线和要分的个数"<<endl;
                       cin>>a>>b>>n;
                       cout<<"积分得: "<<j1(a,b,n)<<endl;
                       c=getchar();
                       system("pause");
                       break;
                case 3:cout<<"simpson: "<<endl;
                       cout<<"请输入积分上下线和要分的个数"<<endl;
                       cin>>a>>b>>n;
                       cout<<"积分得: "<<s1(a,b,n)<<endl;
                       c=getchar();
                       system("pause");
                       break;
                case 4:flag=0;break;
                }
            }
            break;
            case 2:while(flag)
            {
                system("cls");
                cout<<"f(x)=sin(x)"<<endl;
                menu2();
                cin>>l;
                switch(l)
                {
                    case 1:cout<<"梯形法: "<<endl;
                           cout<<"请输入积分上下线和要分的个数"<<endl;
                           cin>>a>>b>>n;
                           cout<<"积分得: "<<t2(a,b,n)<<endl;
                           c=getchar();
                           system("pause");
                           break;
                    case 2:cout<<"矩形法: "<<endl;
                           cout<<"请输入积分上下线和要分的个数"<<endl;
                           cin>>a>>b>>n;
                           cout<<"积分得: "<<j2(a,b,n)<<endl;
                           c=getchar();
                           system("pause");
                           break;
                    case 3:cout<<"simpson: "<<endl;
                           cout<<"请输入积分上下线和要分的个数"<<endl;
                           cin>>a>>b>>n;
                           cout<<"积分得: "<<s2(a,b,n)<<endl;
                           c=getchar();
                           system("pause");
                           break;
                    case 4:flag=0;break;
                   }
            }
            break;
             case 3:while(flag)
             {
                 system("cls");
                 cout<<"f(x)=e^x"<<endl;
                 menu2();
                 cin>>l;
                 switch(l)
                    {
                        case 1:cout<<"梯形法: "<<endl;
                               cout<<"请输入积分上下线和要分的个数"<<endl;
                               cin>>a>>b>>n;
                               cout<<"积分得: "<<t3(a,b,n)<<endl;
                               c=getchar();
                               system("pause");
                               break;
                        case 2:cout<<"矩形法: "<<endl;
                               cout<<"请输入积分上下线和要分的个数"<<endl;
                               cin>>a>>b>>n;
                               cout<<"积分得: "<<j3(a,b,n)<<endl;
                               c=getchar();
                               system("pause");
                               break;
                        case 3:cout<<"simpson: "<<endl;
                               cout<<"请输入积分上下线和要分的个数"<<endl;
                               cin>>a>>b>>n;
                               cout<<"积分得: "<<s3(a,b,n)<<endl;
                               c=getchar();
                               system("pause");
                               break;
                        case 4:flag=0;break;
                   }
             }
                   break;
              case 4:cout<<endl<<"Thanks for use!!"<<endl<<endl;
                     exit(-1);
        }
    }
    return 0;
}
void menu1()
{
    cout<<"                   求定积分"<<endl<<endl;
    cout<<"       1.f(x)=x"<<endl;
    cout<<"       2.f(x0=sin(x)"<<endl;
    cout<<"       3.f(x)=e^x"<<endl;
    cout<<"       4.退出"<<endl;
}
void menu2()
{
    cout<<"     请输入你要用的方法序号:"<<endl<<endl;
    cout<<"1.梯形法:"<<endl;
    cout<<"2.矩形法:"<<endl;
    cout<<"3.Simpson:"<<endl;
    cout<<"4.返回:"<<endl;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值