在数学中,矩阵的“谱半径”是指其特征值的模集合的上确界。换言之,对于给定的 n 个复数空间的特征值 { a1 +b1 i,⋯,an +bn i },它们的模为实部与虚部的平方和的开方,而“谱半径”就是最大模。
现在给定一些复数空间的特征值,请你计算并输出这些特征值的谱半径。
输入格式:
输入第一行给出正整数 N(≤ 10 000)是输入的特征值的个数。随后 N 行,每行给出 1 个特征值的实部和虚部,其间以空格分隔。注意:题目保证实部和虚部均为绝对值不超过 1000 的整数。
输出格式:
在一行中输出谱半径,四舍五入保留小数点后 2 位。
输入样例:
5
0 1
2 0
-1 0
3 3
0 -3
输出样例:
4.24
解题思路:
用结构体做较简单,设置最大元素,遍历结构体数组,找到模的平方最大值,最后在输出模。
代码:
#include<iostream>
#include<iomanip>
#include<cmath>
using namespace std;
struct complex
{
int real, imag;
}plex[10000];
int main()
{
int n, i, max;
cin >> n;
for (i = 0; i < n; i++)
{
cin >> plex[i].real >> plex[i].imag;
}
max = plex[0].real*plex[0].real + plex[0].imag*plex[0].imag;
for (i = 1; i < n; i++)
{
if (plex[i].real*plex[i].real + plex[i].imag*plex[i].imag > max)
{
max = plex[i].real*plex[i].real + plex[i].imag*plex[i].imag;
}
}
cout << setiosflags(ios::fixed) << setprecision(2) << sqrt(max);
return 0;
}
ps:博主能力有限,如果读者发现什么问题,欢迎私信或评论指出不足。欢迎读者询问问题,乐意尽我所能解答读者的问题。欢迎评论,欢迎交流。谢谢大家!