我是网站和一般编程的新手,所以请耐心等待。
我的程序必须满足以下条件:
读取一个正整数
n
,后跟点的 (x,y
) 坐标n
,将这些值存储在一个名为 points 的二维数组中,其中包含n
行和两列。创建一个二维数组,其中的
n
行和n
列名为 distances,distances[i][j] = 从 points[i] 到 points[j] 的距离。创建一个名为 averages 的一维长度数组
n
,averages[i] = 距离行i
的平均值。确定并打印哪个
n
点的平均距离最小。
我似乎对第 3 部分感到困惑,我将如何计算行的平均距离?
到目前为止,这是我的代码,如果有人可以帮助我完成它,我将不胜感激。还要指出我所拥有的任何错误。
import java.util.Scanner;
public class Java
{
public static void main( String[] args )
{
Scanner input = new Scanner(System.in );
System.out.print("How many points: ");
int n = input.nextInt();
double[][] points = new double[n][2];
for(int i = 0; i < n; i++)
{
//prompt or and get coordinates
//points[i][0] = input.nextDouble();
//points[i][1] = input.nextDouble();
}
double[][] distances = new double[n][n];
for(int i = 0; i < n; i++)
for(int j = 0; j < n; j++)
distances[i][j] = distance(points[i], points[j]);
double[] averages = new double[n];
for(int i = 0; i < n; i++)
averages[i] = average( distances[i] );
int which_one = minimum_location( averages );
System.out.printf("Point # %d has a smallest average of %f\n", which_one,
averages[which_one]);
}
public static double distance
(double x1, double y1, double x2, double y2)
{
return Math.sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1));
}
{
public static double average( double[] x);
//problem area
}
{
public static int minimum_location( double[] x );
if (shortestDistance > distance);
{
p1 = i;
p2 = j;
shortestDistance = distance;
}
}