Files
2025-02-Numerical/lib/nr/k_and_r/recipes/snrm.c
2025-09-12 18:55:25 +09:00

24 lines
346 B
C

#include <math.h>
double snrm(n,sx,itol)
double sx[];
int itol;
unsigned long n;
{
unsigned long i,isamax;
double ans;
if (itol <= 3) {
ans = 0.0;
for (i=1;i<=n;i++) ans += sx[i]*sx[i];
return sqrt(ans);
} else {
isamax=1;
for (i=1;i<=n;i++) {
if (fabs(sx[i]) > fabs(sx[isamax])) isamax=i;
}
return fabs(sx[isamax]);
}
}