VC 课程实践正确答案 (1)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
江苏科技大学
课程实践报告
设计题目: 程序设计(VC++)实践
设计时间: 至
学院: 专业班级: 学生姓名: 学号
指导老师:
1.试建立一个类PP,求出下列多项式的前n项的值。
具体要求如下:
(1)私有数据成员
int n:前若干项的项数。
double x:存放x的值。
double *p:根据n的大小动态申请存放Pn(x) 前n项的数组空间。
(2)公有成员函数
PP(int num,double x1):构造函数,初始化数据成员n和x,使p指向动态申请的数组空间。
~PP():析构函数,释放p指向的动态内存空间。
double fun(int n1,double x):递归函数,用于求多项式的第n1项。注意:将递归公式中的n用作函数参数。本函数供process函数调用。
void process( ):完成求前n项的工作,并将它们存放到p指向的动态数组中。
void show( ):输出n和x,并将前n项以每行4个数的形式输出到屏幕上。
(3)在主函数中完成对该类的测试。先输入num和x1,并定义一个PP类的对象items,用num和x1初始化items的成员n和x,调用items的成员函数,求出并输出多项式前num 项的值。
程序源代码
#include
class pp{
int n;
double x;
double *p;
public:
pp(int num,double x1);
~pp();
double fun(int n1,double x);
void process();
void show();
};
pp::pp(int num,double x1)
{
n=num;
x=x1;
p=new double[num+1];
}
pp::~pp()
{
delete []p;
}
double pp::fun(int n1,double x)
{
if(n1==0)return 1;
if(n1==1)return x;
if(n1>1)return ((2*n1-1)*x*fun(n1-1,x)-(n1-1)*fun(n1-2,x))/n1;
}
void pp::process()
{
int i;
for(i=0;i<=n;i++)
{
*(p+i)=fun(i,x);
}
}
void pp::show()
{
cout<<"n="< for(int i=0,m=1;i { cout<<*(p+i)<<'\t'; if(m%4==0)cout<<'\n'; } } void main() { int num; double x1; cout<<"put in num and x1"< cin>>num>>x1; pp items(num,x1); items.process(); items.show(); } 运行结果 2.试建立一个类SP,求,另有辅助函数power(m,n)用于求。具体要求如下: (1)私有成员数据。 int n,k:存放公式中n和k的值; (2)公有成员函数。 SP(int n1,int k1):构造函数,初始化成员数据n和k。 int power(int m, int n):求mn。 int fun( ):求公式的累加和。 void show( ):输出求得的结果。 (3)在主程序中定义对象s,对该类进行测试。 程序源代码 #include class SP{ int n,k; public: SP(int n1,int k1); int power(int m,int n); int fun(); void show(); }; SP::SP(int n1,int k1) { n=n1; k=k1; } int SP::power(int m,int n) { int i; if(n==0)return 1; else for(i=1;i m*=m; return m; } int SP::fun() { int y=0,x; for(x=1;x<=n;x++) y+=power(x,k); return y; } void SP::show() { cout<<"前n项的和为:"< void main() { int n1,k1; cout<<"输入n1和k1的值"<