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

/* (程序头部注释开始)
* 程序的版权和版本声明部分
* 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所以这图就发布上去了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值