复数
如果您已经学习过复数相关知识,请跳过本页面.
学习复数知识需要一部分向量基础,如果并未学习过向量知识请移步 向量页面.
复数
引入
注
下面的引入方法来自人教版高中数学 A 版必修二.
从方程的角度看,负实数能不能开平方,就是方程
回顾已有的数集扩充过程,可以看到,每次扩充都与实际需求密切相关.例如,为了解决正方形对角线的度量,以及
依照这种思想,为了解决
思考:把新引进的数
依照以上设想,把实数
定义
我们定义形如
复数通常用
对于一个复数
纯虚数,虚数,实数,复数的关系如下图所示.
性质与运算
几何意义
我们知道了
我们把所有实数都放在了数轴上,并且发现数轴上的点与实数一一对应.我们考虑对复数也这样处理.
首先我们定义 复数相等:两个复数
这么定义是十分自然的,在此不做过多解释.
也就是说,我们可以用唯一的有序实数对
那么这个平面直角坐标系就不再一般,因为平面直角坐标系中的点具有了特殊意义——表示一个复数,所以我们把这样的平面直角坐标系称为 复平面,
我们考虑到学过的平面向量的知识,发现向量的坐标表示也是一个有序实数对
于是,我们由向量的知识迁移到复数上来,定义 复数的模 就是复数所对应的向量的模.复数
于是为了方便,我们常把复数
并且由向量的知识我们发现,虚数不可以比较大小(但是实数是可以的).
加法与减法
对复数
很明显,两个复数的和仍为复数.
考虑到向量的加法运算,我们发现复数的加法运算符合向量的加法运算法则,这同样证明了复数的几何意义的正确性.
同样可以验证,复数的加法满足 交换律 和 结合律.即:
减法作为加法的逆运算,我们可以通过加法法则与复数相等的定义来推导出减法法则:
这同样符合向量的减法运算.
乘法、除法与共轭
对复数
可以看出,两个复数相乘类似于两个多项式相乘,只需要把
复数的乘法与向量的向量积形式类似.
易得复数乘法满足 交换律,结合律 和 对加法的分配律,即:
由于满足运算律,我们可以发现实数域中的 乘法公式在复数域中同样适用.
除法运算是乘法运算的逆运算,我们可以推导一下:
由于向量没有除法,这里不讨论与向量的关系.
为了分母实数化,我们乘了一个
对复数
对复数
,
辐角和辐角主值
如果设定实数单位
表示复数
从实轴正向到 非零 复数
称为复数
任一个 非零 复数
称
需要注意的是两个辐角主值相加后不一定还是辐角主值,而两个辐角相加一定还是合法的辐角.
称模小于
在极坐标的视角下,复数的乘除法变得很简单.复数乘法,模相乘,辐角相加.复数除法,模相除,辐角相减.
欧拉公式
指数函数与三角函数
对于复数
复指数函数在实数集上与实指数函数的定义完全一致.在复平面上拥有性质:
- 模恒正:
. - 辐角:
. - 加法定理:
. - 周期性:
是以 为基本周期的周期函数.如果一个函数 的周期是某一周期的整倍数,称该周期为 基本周期.
复三角函数(也简称 三角函数)的定义如下:
若取
复三角函数在实数集上与实三角函数的定义完全一致.在复平面上拥有性质:
- 奇偶性:正弦函数是奇函数,余弦函数是偶函数.
- 三角恒等式:通常的三角恒等式都成立,例如平方和为
,或者角的和差公式等. - 周期性:正弦与余弦函数以
为基本周期. - 零点:实正弦与实余弦函数的全体零点,构成了复正弦与复余弦函数的全体零点.这个推广没有引进新的零点.
- 模的无界性:复正弦与复余弦函数,模长可以大于任意给定的正数,不再像实正弦与实余弦函数一样被限制在
的范围内.
复数的三种形式
借助直角坐标系的视角以及极坐标系的视角,可以写出复数的三种形式.
复数的 代数形式 用于表示任意复数.
代数形式用于计算复数的加减乘除四个运算比较方便.
复数的 三角形式 和 指数形式,用于表示非零复数.
这两种形式用于计算复数的乘除两个运算以及后面的运算较为方便.如果只用高中见过的函数,可以使用三角形式.如果引入了复指数函数,写成等价的指数形式会更加方便.
单位根
考察方程
设
如果不加说明,一般叙述中的
为什么通常提到 
次单位根,总是特指第一个?
主要是为了应用时方便.所有
本原单位根
事实上,
中的元素为
任意一个本原单位根
为了理解
性质
对于整数
证明
直接计算可知
这说明,只要
另外,作为这些分析的简单推论,有:
定理
当
尽管本原单位根有很多选择,但是由于第一个根
编程语言中的复数
C 中的复数
在 C99 标准中,有 <complex.h> 头文件.
在 <complex.h> 头文件中,提供了 double complex、float complex 和 long double complex 三种类型.
算术运算符'+'、'-'、'*'和'/',可以用于浮点数和复数的任意混合.当表达式两端有一个为复数时,计算结果为复数.
头文件 <complex.h> 提供了虚数单位 I,引入此头文件时,大写字母 I 不可以作为变量名使用.
对于单个复数,<complex.h> 提供了若干操作:creal 函数用于提取实部,cimag 函数用于提取虚部,cabs 函数用于计算模,carg 函数用于计算辐角主值.
所有的函数根据类型不同,都有三个.例如 creal 函数有 creal、crealf、creall 三个,用于处理对应的 double、float 和 long double 三种类型.末尾什么都不带的默认处理 double 类型.以下所有函数均遵从此规律,不再特别说明.
这些函数返回值都是一般的浮点数.可以将普通浮点数直接赋值给复数,但是不可以将复数直接赋值给浮点数,而是需要使用上述提取操作.
函数 conj 用于计算共轭复数,返回值是复数.
函数 cexp 计算复指数,clog 计算对数主值,csin 计算正弦,ccos 计算余弦,ctan 计算正切.
函数 cpow 计算幂函数,csqrt 计算平方根,casin 计算反正弦,cacos 计算反余弦,catan 计算反正切.这部分函数计算的全部都是多值函数的主值.
C++ 中的复数
在 C 里面的 <ctype.h>,到 C++ 会变成 <cctype>,几乎所有的头文件遵从这个命名规律.
但是,<complex.h> 不遵守,C++ 没有 <ccomplex> 头文件.C++ 的复数直接是 <complex>,并且装的东西和 C 完全不一样.
很有趣.这是因为,在 C++ 的第一个版本 C++98,即已经有了 <complex>,而 C 语言在 C99 才添加.
在 C++ 中,复数类型定义使用 complex<float>、complex<double> 和 complex<long double>.由于面向对象的多态性,下面函数的名字都是唯一的,无需 f 或 l 的后缀.
一个复数对象拥有成员函数 real 和 imag,可以访问实部和虚部.
一个复数对象拥有非成员函数 real、imag、abs、arg,返回实部、虚部、模和辐角.
一个复数对象还拥有非成员函数:norm 为模的平方,conj 为共轭复数.
一个复数对象还拥有非成员函数 exp、log(底为 log10(底为 10 的对数主值,C 中没有)、pow、sqrt、sin、cos、tan,含义与 C 中的含义相同.
在 C++14 及以后的版本中,定义了 字面量运算符 std::literals::complex_literals::""if, ""i, ""il.例如输入 100if、100i 和 100il,三者将分别返回 std::complex<float>{0.0f, 100.0f}、std::complex<double>{0.0, 100.0} 以及 std::complex<long double>{0.0l, 100.0l}.这使得我们可以方便地书写形如 auto z = 4.0 + 3i 的复数声明.
参考资料与链接
- Complex number - Wikipedia
- Euler's formula - Wikipedia
- Complex number arithmetic - cppreference.com
- std::complex - cppreference.com
有关欧拉公式的更多介绍,可以参考两个视频:欧拉公式与初等群论、微分方程概论 - 第五章:在 3.14 分钟内理解
. ↩
本页面最近更新:2026/1/7 08:56:54,更新历史
发现错误?想一起完善? 在 GitHub 上编辑此页!
本页面贡献者:Ir1d, Tiphereth-A, HeRaNO, Enter-tainer, Great-designer, MegaOwIer, Xeonacid, c-forrest, sshwy, CCXXXI, CharlesWuQiushi, chinggg, iamtwz, mcendu, megakite, ouuan, r-value, StudyingFather, TSStudio
本页面的全部内容在 CC BY-SA 4.0 和 SATA 协议之条款下提供,附加条款亦可能应用