complex::complex
Karmaşık bir sayıyı belirtilen reel ve sanal kısımları ile ya da başka bir karmaşık sayı bir kopyasını oluşturur.
complex(
const Type& _RealVal = 0,
const Type& _ImagVal = 0
);
template<class Other>
complex(
const complex<Other>& _ComplexNum
);
Parametreler
_RealVal
Oluşturulmuş karmaşık sayı başlatmak için kullanılan gerçek bölümü değeri._ImagVal
Oluşturulmuş karmaşık sayı başlatmak için kullanılan sanal kısmı değeri._ComplexNum
Karmaşık, gerçek ve sanal kısımları oluşturulamıyor karmaşık sayının başlatmak için kullanılan sayı.
Notlar
İlk kurucu saklı başlatır _ gerçek KısımRealVal ve saklı sanal kısmı için _Imagval.İkinci kurucu saklı başlatır gerçek bir bölümü için _ComplexNum**.real**() ve saklı sanal kısmı için _ComplexNum**.imag**().
Bir çevirmen üye şablonu İşlevler, şablon desteklemiyorsa, bu uygulama:
template<class Other>
complex(const complex<Other>& right);
değiştirilir:
complex(const complex& right);
kopya kurucusu olduğu.
Örnek
// complex_complex.cpp
// compile with: /EHsc
#include <complex>
#include <iostream>
int main( )
{
using namespace std;
double pi = 3.14159265359;
// The first constructor specifies real & imaginary parts
complex <double> c1 ( 4.0 , 5.0 );
cout << "Specifying initial real & imaginary parts,"
<< "c1 = " << c1 << endl;
// The second constructor initializes values of the real &
// imaginary parts using those of another complex number
complex <double> c2 ( c1 );
cout << "Initializing with the real and imaginary parts of c1,"
<< " c2 = " << c2 << endl;
// Complex numbers can be initialized in polar form
// but will be stored in Cartesian form
complex <double> c3 ( polar ( sqrt( (double)8 ) , pi / 4 ) );
cout << "c3 = polar ( sqrt ( 8 ) , pi / 4 ) = " << c3 << endl;
// The modulus and argument of a complex number can be recovered
double absc3 = abs ( c3 );
double argc3 = arg ( c3 );
cout << "The modulus of c3 is recovered from c3 using: abs ( c3 ) = "
<< absc3 << endl;
cout << "Argument of c3 is recovered from c3 using:\n arg ( c3 ) = "
<< argc3 << " radians, which is " << argc3 * 180 / pi
<< " degrees." << endl;
}
Çıktı
Specifying initial real & imaginary parts,c1 = (4,5)
Initializing with the real and imaginary parts of c1, c2 = (4,5)
c3 = polar ( sqrt ( 8 ) , pi / 4 ) = (2,2)
The modulus of c3 is recovered from c3 using: abs ( c3 ) = 2.82843
Argument of c3 is recovered from c3 using:
arg ( c3 ) = 0.785398 radians, which is 45 degrees.
Gereksinimler
Başlık: <complex>
Namespace: std