{
return Complex(c1.Real-c2.Real,c1.Imag-c2.Imag);
}
Complex operator *(const Complex c1,const Complex c2)
{
return Complex(c1.Real*c2.Real-c1.Imag*c2.Imag,c1.Real*c2.Imag+c2.Real*c1.Imag);
}
Complex operator /(const Complex c1,const Complex c2)
{
double m=c2.Real*c2.Real+c2.Imag*c2.Imag;
return Complex((c1.Real*c2.Real+c1.Imag*c2.Imag)/m,(c1.Imag*c2.Real-c1.Imag*c2.Imag)/m);
}
int main()
{
Complex c1(1,2),c2(3,4);
c1.print();
c2.print();
Complex c3;
c3=c1+c2;
c3.print();
c3=c1-c2;
c3.print();
c3=c1*c2;
c3.print();
c3=c1/c2;
c3.print();
return 0;
}
(3)分析下面程序,给出横线部分的语句,写出程序的输出结果并分析m_count的功能。
#include
using namespace std;
class A {
static int m_counter;
public:
A();
~A();
staticvoid display();
}
—————————— //将m_counter初始化为0;
A::A()
{
m_counter++;
}
A::~A()
{
m_counter--;
}
void A::display()
{
cout<<”There are:”< } int main() { A a1; A a2; A a3; A::display(); a1.display(); } (4)商店经销一种货物,货物成箱购进,成箱卖出,购进和卖出时以重量为单位,各箱的重量不一样,单价不一样,因此商店需要记录下目前库存的货物的总重量和总价值。编写一个程序,通过定义类Carlo来模拟商店货物购进和卖出的情况。 (本题目主要练习静态数据成员的使用,定义私有变量存每件货物的价格和重量,用静态数据成员存货物的总重量和总价钱,定义构造函数和析构函数,当定义新的对象完成初始化的功能和删除对象时,从总重量和总价钱中减去对象的重量和价格) (5) 静态成员练习 1) 编写一个类Node,声明一个数据成员member和已经静态成员count,另构造函数初始化数据成员,并把静态数据成员加1,另析构函数把静态数据成员减1。 2) 在1)的基础上编写应用程序,创建3个对象,然后显示他们的数据成员和静态成员,再析构每个对象,并显示他们对静态数据成员的影响。 3) 修改2),让静态成员函数访问静态数据成员,并让静态数据成员是私有的。 (6)两个类分别为整型数集合类和实型数集合数类。将缺少的内容补齐。并完成要求的其它内容。 如: class Intset { private: int num[3]; public: Intset ( int x,int y, int z) {//添加初始化内容} void print( ) { //打印数据} }; class floatset { private: float num[3]; public: floatset ( float x,float y, float z) { //添加初始化内容 } void print( ) { //打印数据 } }; (1)在Intset中再增加一个成员函数,将对象的整型数据拷贝的到floatset的对象中此成员函数的原型为: void settofloat(floatset &set); //形参为拷贝的目标对象 (2)定义一个友元函数来实现上述的功能。 请分别完成两个程序。 (7) 分析以下程序的功能,把程序用三种方法(公有数据成员、友元、用成员函数访问私有数据成员)补充完整,实现对对象Animal的成员 #include class Animal; void SetValue(Animal&, int); void SetValue(Animal&, int, int); class Animal { public: Animal():itsWeight(0),itsAge(0){} voidshow(){cout< protected: intitsWeight; intitsAge; }; void SetValue(Animal& ta, int tw) { // 设置itsWeight值 } void SetValue(Animal& ta, int tw, inttn) { // 设置itsWeight和itsAge值 } int main() { Animalpeppy; SetValue(peppy,5); peppy.show(); SetValue(peppy,7, 9); peppy.show(); return0; } (8) 设计一个整数链表类,满足栈操作。即,总在链表首插入结点,总在链表首取出(删除)结点。类中需有记录结点个数的数据成员。如果链表为空,而要做取出结点操作,则类必须给出错误信息。 编写应用程序,取100次随机数(范围10-200),每取到比前一个随机数大时,放入链表中,否则,略去。然后逐个取出,求其和。 用堆分配方法逐个产生满足条件的结点,插入链表中。每当从链表中取出一个结点时,要及时将结点删除。 求和工作不要在链表类中完成,以使该链表类具有通用性。 (9) 设计合适的类结构,完成多项式加、减、乘运算。