/*
* 程式的著作權和版本聲明部分
* Copyright (c) 2011, 煙台大學電腦學院學生
* All rights reserved.
* 檔案名稱:
* 作 者: 張傳新
* 完成日期:2012 年04月03日
* 版 本 號:1.0
* 對任務及求解方法的描述部分
* 輸入描述:
* 問題描述:類模板的應用
* 程式輸出:
* 問題分析:……
* 演算法設計:……
*/
#include <iostream>using namespace std;template<class comp>class Complex {public:Complex( ){real=0;imag=0;} Complex(comp r,comp i){real=r;imag=i;} Complex complex_add(Complex &c2); Complex complex_sub(Complex &c2);Complex complex_mul(Complex &c2); Complex complex_div(Complex &c2); void display( ); private:comp real; comp imag; };template<class comp>//每一個成員函數的定義前,必須要聲明類模板,加法 Complex<comp> Complex<comp>::complex_add(Complex &c2){Complex c;c.real=real+c2.real;c.imag=imag+c2.imag;return c;} template<class comp> //減法Complex<comp> Complex<comp>::complex_sub(Complex &c2){Complex c;c.real=real-c2.real;c.imag=imag-c2.imag;return c;} template<class comp> //乘法 Complex<comp> Complex<comp>::complex_mul(Complex &c2){Complex c;c.real=real*c2.real-imag*c2.imag;c.imag=imag*c2.real+c2.imag*real;return c;} template<class comp> //除法Complex<comp> Complex<comp>::complex_div(Complex &c2){Complex c;c.real=(real*c2.real+imag*c2.imag)/(c2.real*c2.real+c2.imag*c2.imag);c.imag=(imag*c2.real-real*c2.imag)/(c2.real*c2.real+c2.imag*c2.imag);return c;} template<class comp> void Complex<comp>::display( ) {cout<<"("<<real<<","<<imag<<"i)"<<endl;}int main( ){Complex<int> c1(0,0),c2(1,1),c3;//定義對象時,形式為“類模板名<實際類型名>” c3=c1.complex_add(c2);cout<<"c1+c2="; c3.display( ); c3=c1.complex_sub(c2);cout<<"c1-c2="; c3.display( );c3=c1.complex_mul(c2);cout<<"c1*c2="; c3.display( );c3=c1.complex_div(c2);cout<<"c1/c2="; c3.display( );Complex<double> c4(3.1,4.4),c5(5.34,-10.21),c6; c6=c4.complex_add(c5); cout<<"c4+c5="; c6.display( );c6=c4.complex_sub(c5);cout<<"c1-c2="; c6.display( );c6=c4.complex_mul(c5);cout<<"c1*c2="; c6.display( );c6=c4.complex_div(c5);cout<<"c1/c2="; c6.display( );system("pause");return 0;}
運行結果:
積累:突然覺得,一個項目的完成迫切需要團隊配合,一個人的程式總有不足的地方,多交流會發現,
這個世界的另一種存在!