我正在创建代码以帮助自己完成一些功课,但是“ C”类存在问题。它一直给我NaN输出,您能看看并告诉我我做错了吗?
我仔细检查了一下,发现问题出在这行:
C[i][j] = C[i][j] * (Math.sqrt(((Math.pow(U[i][j],2)/Math.pow(I[i][j],2)))-Math.pow(R[i],2)));
主要-
public class Main {
public static void main(String[] args) {
Wzory wzor = new Wzory();
wzor.scan();
wzor.xU();
wzor.xI();
wzor.C();
}
}
package FizA;
import java.util.Scanner;
import java.lang.Math;
public class Wzory {
//przypisane
double[] f = new double[2],xf = new double[2],R = new double[2],xR = new double[2];
double[][] U = new double[2][4],I = new double[2][4];
double pi=3.1415;
//obliczone
double[][] xU = new double[2][4], xI = new double[2][4], C = new double[2][4], xC = new double[2][4];
public void scan()
{
Scanner scan = new Scanner(System.in);
for(int i=0; i<2; i++)
{
System.out.println("Podaj 'f':");
f[i] = scan.nextDouble();
System.out.println("Podaj 'xf':");
xf[i] = scan.nextDouble();
System.out.println("Podaj 'R':");
R[i] = scan.nextDouble();
System.out.println("Podaj 'xR':");
xR[i] = scan.nextDouble();
for(int j=0; j<4; j++)
{
System.out.println("Podaj 'U':");
U[i][j] = scan.nextDouble();
System.out.println("Podaj 'I':");
I[i][j] = scan.nextDouble();
}
}
scan.close();
}
public void xU()
{
for(int i=0; i<2; i++)
{
for(int j=0; j<4; j++)
{
xU[i][j] = 0.005 * U[i][j];
xU[i][j] = xU[i][j] + 0.003;
System.out.println("xU-"+i+","+j+"="+xU[i][j]);
}
}
}
public void xI()
{
for(int i=0; i<2; i++)
{
for(int j=0; j<4; j++)
{
xI[i][j] = 0.015 * I[i][j];
xI[i][j] = xI[i][j] + 0.000003;
System.out.println("xI"+i+","+j+"="+xI[i][j]);
}
}
}
public void C()
{
for(int i=0; i<2; i++)
{
for(int j=0; j<4; j++)
{
C[i][j] = 2*pi*f[i];
C[i][j] = C[i][j] * (Math.sqrt(((Math.pow(U[i][j],2)/Math.pow(I[i][j],2)))-Math.pow(R[i],2)));
C[i][j] = Math.pow(C[i][j],-1);
System.out.println("C"+i+","+j+"="+C[i][j]);
}
}
}
}
答案 0 :(得分:1)
您正在对此取平方根,Math.pow(U [i] [j],2)/Math.pow(I [i] [j],2)))-Math.pow(R [ i],2)
您的NaN来自:
1)Math.sqrt方法
2)和减去Math.pow(R [i],2),因为负数没有平方根,所以平方可以是0或正数。
示例:
当U [i] [j]等于2的幂/ I [i] [j]等于2的幂时,R [i]等于2的幂时,给出一个负数,您的Math.sqrt即使您将其乘以C [i] [j]并将其存储回C [i] [j]并打印,它的负数也会给出NaN。
这就是您获得NaN的方式。