C++ åèæå
- C++11
- C++14
- C++17
- C++20
- C++ ç¼è¯å¨æ¯ææ åµè¡¨
- ç¬ç«ä¸å®¿ä¸»å®ç°
- C++ è¯è¨
- C++ å ³é®è¯
- é¢å¤çå¨
- C++ æ ååºå¤´æä»¶
- å ·åè¦æ±
- åè½ç¹æ§æµè¯ (C++20)
- å·¥å ·åº
- ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼
- æ¦å¿µåº (C++20)
- é误å¤ç
- 卿å å管ç
- æ¥æåæ¶é´å·¥å ·
- å符串åº
- 容å¨åº
- è¿ä»£å¨åº
- èå´åº (C++20)
- ç®æ³åº
- æ°å¼åº
- å¸¸ç¨æ°å¦å½æ°
- æ°å¦ç¹æ®å½æ°
- ä¼ªéæºæ°çæ
- æµ®ç¹ç¯å¢
- std::complex
- std::complex<T>::complex
- std::complex<T>::operator=
- std::complex<T>::real
- std::literals::complex_literals::operator""i, operator""if, operator""il
- std::complex<T>::imag
- std::complex<T>::operator+=,-=,*=,/=
- std::complex<T>::operator+(unary), operator-(unary)
- operator+,-,*,/ (std::complex)
- operator==,!=(std::complex)
- operator<<,>>(std::complex)
- std::real(std::complex)
- std::imag(std::complex)
- std::abs(std::complex)
- std::arg(std::complex)
- std::norm(std::complex)
- std::conj(std::complex)
- std::proj(std::complex)
- std::polar(std::complex)
- std::exp(std::complex)
- std::log(std::complex)
- std::log10(std::complex)
- std::pow(std::complex)
- std::sqrt(std::complex)
- std::sin(std::complex)
- std::cos(std::complex)
- std::tan(std::complex)
- std::asin(std::complex)
- std::acos(std::complex)
- std::atan(std::complex)
- std::sinh(std::complex)
- std::cosh(std::complex)
- std::tanh(std::complex)
- std::asinh(std::complex)
- std::acosh(std::complex)
- std::atanh(std::complex)
- std::midpoint
- std::lerp
- std::has_single_bit
- std::bit_ceil
- std::bit_floor
- std::bit_width
- std::rotl
- std::valarray
- ç¼è¯æ¶æçæ°ç®æ¯
- std::gcd
- std::lcm
- æ°å¦å¸¸æ°
- std::bit_cast
- std::rotr
- std::countl_zero
- std::countl_one
- std::countr_zero
- std::countr_one
- std::popcount
- 注é
- è¾å ¥/è¾åºåº
- æä»¶ç³»ç»åº
- æ¬å°ååº
- æ£å表达å¼åº
- ååæä½åº
- çº¿ç¨æ¯æåº
- å®éªæ§ C++ ç¹æ§
- æç¨çèµæº
- ç´¢å¼
- std 符å·ç´¢å¼
- åç¨æ¯æ (C++20)
- C++ å ³é®è¯
ä½ç½®ï¼é¦é¡µ > C++ åèæå >æ°å¼åº >std::complex > std::sqrt(std::complex)
std::sqrt(std::complex)
| å®ä¹äºå¤´æä»¶ <complex>
|
||
| template< class T > complex<T> sqrt( const complex<T>& z ); |
||
计ç®å¤æ° z çå¹³æ¹æ ¹ï¼åæ¯å岿²¿è´å®è½´ã
åæ°
| z | - | è¦åå¹³æ¹æ ¹ç夿° |
è¿åå¼
è¥ä¸åºç°é误ï¼åè¿å z çå¹³æ¹æ ¹ï¼å¨å
å«èè½´çå³åå¹³é¢ä¸ï¼æ²¿å®è½´ä¸º [0; +â) ï¼è沿è轴为 (ââ; +â) ï¼ã
é误å¤çåç¹æ®å¼
æ¥åçéè¯¯ä¸ math_errhandling ä¸è´ã
è¥å®ç°æ¯æ IEEE æµ®ç¹ç®æ¯ï¼å
- èèèé¨ç¬¦å·ï¼å½æ°è¿ç»å°åæ¯åå²ä¸
- std::sqrt(std::conj(z)) == std::conj(std::sqrt(z))
- è¥
z为(±0,+0)ï¼åç»æä¸º(+0,+0) - è¥
z为(x,+â)ï¼åç»æä¸º(+â,+â)ï¼å³ä½¿ x 为 NaN - è¥
z为(x,NaN)ï¼åç»æä¸º(NaN,NaN)ï¼é¤é x 为 ±â ï¼å¹¶å¯è½å¼å FE_INVALID - è¥
z为(-â,y)ï¼åå¯¹äºæéæ£ y ç»æä¸º(+0,+â) - è¥
z为(+â,y)ï¼åå¯¹äºæéæ£ y ç»æä¸º(+â,+0) - è¥
z为(-â,NaN)ï¼åç»æä¸º(NaN,â)ï¼èé¨ç¬¦å·æªæå®ï¼ - è¥
z为(+â,NaN)ï¼åç»æä¸º(+â,NaN) - è¥
z为(NaN,y)ï¼åç»æä¸º(NaN,NaN)å¹¶å¯è½å¼å FE_INVALID - è¥
z为(NaN,NaN)ï¼åç»æä¸º(NaN,NaN)
注æ
æ¤å½æ°çè¯ä¹ææä¸ C 彿° csqrt ä¸è´ã
ç¼ºé·æ¥å
ä¸åæ´æ¹è¡ä¸ºçç¼ºé·æ¥å追溯å°åºç¨äºä»¥ååºçç C++ æ åã
| DR | åºç¨äº | åºçæ¶çè¡ä¸º | æ£ç¡®è¡ä¸º |
|---|---|---|---|
| LWG 2597 | C++98 | è§å®éå¤çæç¬¦å·é¶èé¨æè¯¯ | ç§»é¤äºé误çè¦æ± |
示ä¾
è¿è¡æ¤ä»£ç
#include <iostream> #include <complex> Â int main() { std::cout << "Square root of -4 is " << std::sqrt(std::complex<double>(-4, 0)) << '\n' << "Square root of (-4,-0), the other side of the cut, is " << std::sqrt(std::complex<double>(-4, -0.0)) << '\n'; }
è¾åºï¼
Square root of -4 is (0,2) Square root of (-4,-0), the other side of the cut, is (0,-2)
åé
| 夿°å¹ï¼ä¸æä¸¤ä¸ªåæ°å¯ä¸ºå¤æ° (彿°æ¨¡æ¿) | |
| (C++11)(C++11) |
计ç®å¹³æ¹æ ¹ï¼ âx ï¼ (彿°) |
| åºç¨å½æ° std::sqrt å° valarray çæ¯ä¸ªå
ç´ (彿°æ¨¡æ¿) |