命名空间
变体
操作

std::conj(std::complex)

来自 cppreference.cn
< cpp‎ | numeric‎ | complex
 
 
 
 
定义于头文件 <complex>
(1)
template< class T >
std::complex<T> conj( const std::complex<T>& z );
(直到 C++20)
template< class T >
constexpr std::complex<T> conj( const std::complex<T>& z );
(自 C++20 起)
附加重载 (自 C++11 起)
定义于头文件 <complex>
(A)
std::complex<float>       conj( float f );

std::complex<double>      conj( double f );

std::complex<long double> conj( long double f );
(直到 C++20)
constexpr std::complex<float>       conj( float f );

constexpr std::complex<double>      conj( double f );

constexpr std::complex<long double> conj( long double f );
(自 C++20 起)
(直到 C++23)
template< class FloatingPoint >
constexpr std::complex<FloatingPoint> conj( FloatingPoint f );
(自 C++23 起)
(B)
template< class Integer >
constexpr std::complex<double> conj( Integer i );
(直到 C++20)
template< class Integer >
constexpr std::complex<double> conj( Integer i );
(自 C++20 起)
1) 计算 z复共轭,方法是反转虚部的符号。
A,B) 为所有整数和浮点类型提供了额外的重载,它们被视为虚部为零的复数。
(自 C++11 起)

目录

[edit] 参数

z - 复数值
f - 浮点数值
i - 整数值

[edit] 返回值

1) z 的复共轭。
A) std::complex(f)
B) std::complex<double>(i)

[edit] 注解

附加的重载不需要完全按照 (A,B) 的形式提供。它们只需要足以确保对于它们的参数 num

  • 如果 num 具有标准(直到 C++23)浮点类型 T,则 std::conj(num) 具有与 std::conj(std::complex<T>(num)) 相同的效果。
  • 否则,如果 num 具有整数类型,则 std::conj(num) 具有与 std::conj(std::complex<double>(num)) 相同的效果。

[edit] 示例

#include <complex>
#include <iostream>
 
int main()
{
    std::complex<double> z(1.0, 2.0);
    std::cout << "The conjugate of " << z << " is " << std::conj(z) << '\n'
              << "Their product is " << z * std::conj(z) << '\n';
}

输出

The conjugate of (1,2) is (1,-2)
Their product is (5,0)

[edit] 参见

返回复数的幅值
(函数模板) [编辑]
返回幅值的平方
(函数模板) [编辑]
从幅值和相位角构造复数
(函数模板) [编辑]
C 文档 关于 conj