gpt4 book ai didi

java - java内部类的排序 vector

转载 作者:行者123 更新时间:2023-12-01 23:25:29 25 4
gpt4 key购买 nike

我正在学习java,我必须将程序从c++更改为java。对于输入:1026 7712 3714 1819 9671 9591 998 4366 772 7594 91我收到错误。我以前从未使用过比较器。谁能告诉我我做错了什么。

import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;
import java.util.Vector;

public class Main {
static int n;

static public class punct
{
public int x;
public int y;
}

static punct v[];
static Vector <punct> vec;
static boolean sortY(punct a,punct b)
{
return (a.y < b.y);
}

static boolean sortX(punct a,punct b)
{
return (a.x < b.x);
}

static int myDistance(punct a1,punct a2)
{

return ((a1.x - a2.x) * (a1.x - a2.x) + (a1.y - a2.y) * (a1.y - a2.y)) ;
}

static int devideAndConquer(int left,int right)
{
int d;
int c;
if(right - left <= 2)
{
d = (1000000000);

for(int i = left; i < right ; i++ )
{
for(int j = i + 1 ; j<= right; j++)
{
d = Math.min(myDistance(v[i], v[j]),d);
}
}
Arrays.sort(v,new Comparator <punct>()
{
public int compare(punct a, punct b)
{
return (int) a.y - b.y;
}
});

return d;
}
else
{
int middle = left + (right - left) / 2;

d = Math.min(devideAndConquer(left, middle),devideAndConquer(middle + 1, right));

int l = left;
int r = middle+1;

vec.clear();
while( (l <= middle) && (r <= right) )
{
if( sortY(v[l], v[r]) == true)
{
vec.add(v[l]);
l++;
}
else
{
vec.add(v[r]);
r++;
}
}

while( l <= middle )
{
vec.add(v[l]);
l++;
}

while( r <= right )
{
vec.add(v[r]);
r++;
}

for(int i = left, k = 0; i<=right; i++,k++)
{
v[i] = vec.get(k);
}

for(int i = left ; i<= right ; i++)
{
for(int j = i+1; (j <= right) && (j-i < 7) ; j++)
{
d = Math.min(myDistance(v[i],v[j]),d);
}
}

return d;
}
}

static void read()
{
Scanner scanner = new Scanner(System.in);
n = scanner.nextInt();
v = new punct [n+10];
punct a = new punct();
for(int i = 0; i<=n-1;i++)
{
a.x = scanner.nextInt();
a.y = scanner.nextInt();
v[i] = a;
}
scanner.close();
}

static void write(int d)
{
double x = Math.sqrt(d);
System.out.print(x);
}
public static void main(String args[])
{
read();
Arrays.sort(v,new Comparator <punct>(){
public int compare(punct a, punct b)
{
return a.x - b.x;
}
});
int d = devideAndConquer(0,n-1);
}
}

最佳答案

您的 read() 方法存在一个问题

改变

    punct a = new punct();  //this line should be in your for loop
for(int i = 0; i<=n-1;i++)
{
a.x = scanner.nextInt();
a.y = scanner.nextInt();
v[i] = a;
}

    for(int i = 0; i<=n-1;i++)
{
punct a = new punct(); //moved inside the loop
a.x = scanner.nextInt();
a.y = scanner.nextInt();
v[i] = a;
}

还有一个问题

改变

   n = scanner.nextInt();
v = new punct [n+10];

    n = scanner.nextInt();
v = new punct [n];

哦,我错过了这个

改变

  static Vector <punct> vec;

 static Vector <punct> vec = new Vector<punct>();

关于java - java内部类的排序 vector ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20069167/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com