第八周实验报告(一.3)

来源:互联网 发布:刀剑乱舞国服辅助软件 编辑:程序博客网 时间:2024/04/29 07:59
/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生 
* All rights reserved.
* 文件名称:                              
* 作    者:   李腾                           
* 完成日期: 2012        年   4    月  9      日
* 版 本 号:          


* 对任务及求解方法的描述部分
* 输入描述: 
* 问题描述: 
* 程序输出: 
* 程序头部的注释结束

*/

#include<iostream> 
using namespace std; 
class Complex 

public: 
    Complex(){real=0;imag=0;} 

    Complex(double r,double i){real=r;imag=i;} 

    friend Complex operator+(Complex &c1,Complex &c2);         //声明重载函数加作为友元函数 
 
    friend Complex operator-(Complex &c1,Complex &c2);         //声明重载函数减作为友元函数 
 
    friend Complex operator*(Complex &c1,Complex &c2);         //声明重载函数加乘作为友元函数 
 
    friend Complex operator/(Complex &c1,Complex &c2);         //声明重载函数除作为友元函数
 
    friend Complex operator+(Complex &c1, const double &d);    //声明重载函数第一个参数可以不是类对象  

    friend Complex operator+(const double &d,Complex &c1);     //声明重载函数第二个参数可以不是类对象 
 
    friend Complex operator-(Complex &c2);                     //声明一目运算符形如"-c"  

    void display(); 

private: 
    double real; 
    double imag; 
}; 
//定义友元函数加法  
Complex operator+(Complex &c1,Complex &c2) 

    return Complex(c1.real + c2.real,c1.imag + c2.imag); 

//定义复数加double型的数  
Complex operator+(Complex &c1,const double &d) 

    return Complex(c1.real + d,c1.imag); 

Complex operator+(const double &d,Complex &c1) 

    return Complex(c1.real + d,c1.imag); 

//定义友元函数减法  
Complex operator-(Complex &c1,Complex &c2) 

    return Complex(c1.real - c2.real,c1.imag - c2.imag); 

//定义一目运算符形如"-c"  
Complex operator-(Complex &c2)   
{   
    return Complex(-c2.real, -c2.imag);   
}  
//定义友元函数乘法  
Complex operator*(Complex &c1,Complex &c2) 

    Complex c;     
    c.real = c1.real*c2.real - c1.imag*c2.imag;     
    c.imag = c1.real*c2.imag + c1.imag*c2.real;     
    return c; 

//定义友元函数除法  
Complex operator/(Complex &c1,Complex &c2) 
{     
    Complex c;     
    c.real = (c1.real*c2.real + c1.imag*c2.imag)/(c2.real*c2.real+c2.imag*c2.imag);     
    c.imag = (-c1.real*c2.imag + c1.imag*c2.real)/(c2.real*c2.real+c2.imag*c2.imag);    
    return c;     
}  
void Complex::display() 
{     
    cout<<"("<<real<<","<<imag<<"i)"<<endl;     
}  
int main() 

 
    Complex c1(3,4),c2(5,-10),c3; 
    cout<<"c1="; 
    c1.display(); 
    cout<<"c2="; 
    c2.display(); 
    c3=c1+c2; 
    cout<<"c1+c2="; 
    c3.display(); 
    c3=c1-c2; 
    cout<<"c1-c2="; 
    c3.display(); 
    c3=c1*c2; 
    cout<<"c1*c2="; 
    c3.display(); 
    c3=c1/c2; 
    cout<<"c1/c2="; 
    c3.display(); 
    c3=6+c1; 
    cout<<"6+c1="; 
    c3.display(); 
    c3=c1+6; 
    cout<<"c1+6="; 
    c3.display(); 
    c3=-c2; 
    cout<<"-c2="; 
    c3.display(); 
    system("pause"); 
    return 0; 
}

感悟:晕!!真不知道我自己开始是怎么理解这道题的,偏差有点大,幸好瞅瞅他们的要不我还不知道的卡到什么时候呢,不过发现了自己的c++水平还是和他们有点差距,继续努力哈!!发现309竟然没有VS2008所以这图就发布上去了。

原创粉丝点击