#java #arrays #arraylist
#java #массивы #arraylist
Вопрос:
Извините за то, что это простой вопрос, но как мне настроить метод toString() для списка массивов?
это так просто, как
points = new ArrayList<Point>();
public String toString() {
return points.toString();}
который, похоже, не работает для меня, или это было бы сложнее, поскольку это список массивов? Потому что по какой-то причине, когда я выполняю мой таким образом, он печатает только первое значение или объект.
P.S Я пытаюсь вернуть все значения, которые я уже добавил в свой список.
Более подробно конструктор
public Cloud() {
points = new ArrayList<Point>();
}
добавить точку
public void addPoint(Point p) { // done
if (points.contains(p)) {
// if p is already in the list it does nothing
} else {
points.add(p); // if p was not in the list it adds it to the end
}
}
toString
public String toString() {
return points.toString();
}
Главная
public static void main(String[] args) {
Cloud cloud = new Cloud();
cloud.setDebug(false);
System.out.println("cloud.debug OFF");
System.out.println("initial cloud: " cloud.toString());
Point p1 = new Point(3.0, 1.0);
cloud.addPoint(p1);
Point p2 = new Point(2.0, 2.0);
cloud.addPoint(p2);
Point p3 = new Point(1.5, 1.5);
cloud.addPoint(p3);
Point p4 = new Point(3.0, 0.0);
cloud.addPoint(p4);
System.out.println("final cloud: " cloud);
Это просто печать окончательного облака: (3.0,1.0), в то время как оно должно печатать окончательное облако: [(3.0,1.0), (2.0,2.0), (1.5,1.5), (3.0,0.0)]
редактировать: класс точек
public class Point {
private double x;
private double y;
public static final double EPSILON = 1e-5;
public static boolean debug = false;
public Point(double x, double y) {
this.x = x;
this.y = y; // Done sets the x,y private types to the x,y type provided
// in the ()
}
public Point() {
this(0.0, 0.0); // calls the point (double x,double) constructer with
// the given arguments
} // inturn setting x and y == 0.0
public double getX() {
return x; // returns the private value of x when called in the main
// method
} // so it can't be changed by the user
public double getY() {
return y; // return the private value of y when called in the main
// method so it can't be changed
} // by the user
public String toString() {
return "(" x "," y ")"; // done by teacher sets the toString
// method and implemetns it
}
public boolean equals(Point p) {
if (Math.abs(this.getX()) - Math.abs(p.x) < EPSILON) {
return true; // checks if x - p.x is less than epsilon which covers
// the round off
}
if (Math.abs(this.getY()) - Math.abs(p.y) < EPSILON) {
return true; // checks if y-p.y is less than epsilon which covers
// the round off
}
return false; // both these methods test for equality using epsilon,
// becuae we are dealing with
} // doubles, so roundof can occur
public boolean equals(Object obj) { // this was given to us
if (obj instanceof Point) {
Point p = (Point) obj; // This method overrides the object equals
// method and the calls
return equals(p); // the clas's equals(point) method
}
return false;
}
// TODO Implement Point.euclidDist
/**
*
* @param p
* @return Euclidean distance of this point to point p
*/
public double euclidDist(Point p) {
double distance = 0;
double firstvalue;
double secondvalue;
distance = Math.sqrt(((this.getX() - p.x) * (this.getX() - p.x)) // calculate
// the
// distance
((this.getY() - p.y) * (this.getY() - p.y))); // between the
// two points
// firstvalue= Math.pow(this.getX()-p.x, 2);
// secondvalue= Math.pow(this.getY()-p.y, 2);
// distance = Math.sqrt(firstvalue secondvalue);
return distance;
}
/**
* @param args
* : no args
*/
public static void main(String[] args) {
// test all methods
if (debug)
System.out.println("debug ON");
else
System.out.println("debug OFF");
System.out.println("EPSILON: " Point.EPSILON);
Point origin = new Point();
Point p1 = new Point(0.0, 4.0);
Point p2 = new Point(3.0000001, 3.9999999);
Point p3 = new Point(3.0, 4.0);
Point p4 = new Point(0.0, 5.0);
Point p5 = new Point(12.0, 0.0);
System.out.println("origin: " origin);
System.out.println("p1: " p1);
System.out.println("p2: " p2);
System.out.println("p3: " p3);
System.out.println("p4: " p4);
System.out.println("p5: " p5);
if (p2.equals(p3))
System.out.println(p2 " equals " p3);
else
System.out.println(p2 " does not equal " p3);
System.out.println("Euclidean distance between " origin " and "
p1 ": " origin.euclidDist(p1));
System.out.println("Euclidean distance between " p1 " and " p3
": " p1.euclidDist(p3));
System.out.println("Euclidean distance between " p3 " and "
origin ": " p3.euclidDist(origin));
System.out.println("Euclidean distance between " p4 " and " p5
": " p4.euclidDist(p5));
}
}
Комментарии:
1. Вам также необходимо переопределить
toString()
Point
класс in.2. @NikhilTalreja: проблема не в этом. У Point уже есть toString . Проблема в данных, которые он добавляет в список.
3. Где код для
Point
класса?4. Просто совет, поскольку вы допустили ошибку во второй раз, вам не следует оставлять личную информацию в своем коде, когда вы публикуете ее в Интернете…
Ответ №1:
Вы можете создавать toString()
переопределения методов только в своих классах, а не в других классах, которые вы не переопределяете. У ArrayList уже есть допустимый toString()
метод, который является полезным. Вам просто нужно будет убедиться, что элементы, содержащиеся в списке, принадлежат классу, который также имеет допустимый метод toString().
Обратите внимание, что вы заявляете:
что, похоже, не работает на меня… Потому что по какой-то причине, когда я выполняю мой таким образом, он печатает только первое значение или объект.
Это говорит о том, что у вас нет проблемы с toString() , но на самом деле у вас есть другая, совершенно другая проблема с вашей программой, заключающаяся в том, что вы неправильно добавляете объекты в список. Вам нужно выполнить больше отладки и показать более подходящий код.
Редактировать
Я предполагаю, что метод вашего класса Point contains(...)
ошибочен, что он возвращается true
, когда он должен возвращать false . Пожалуйста, покажите нам класс Point.
Правка 3 (удаленная правка 2) Ваши значения неверны:
Это нормально:
public boolean equals(Object obj) { // this was given to us
if (obj instanceof Point) {
Point p = (Point) obj; // This method overrides the object equals
// method and the calls
return equals(p); // the clas's equals(point) method
}
return false;
}
Но здесь вы возвращаете equals, если либо x, либо y близко совпадают, а этого не должно быть. Вы должны возвращать true только в том случае, если ОБА близко совпадают:
public boolean equals(Point p) {
if (Math.abs(this.getX()) - Math.abs(p.x) < EPSILON) {
return true; // checks if x - p.x is less than epsilon which covers
// the round off
}
if (Math.abs(this.getY()) - Math.abs(p.y) < EPSILON) {
return true; // checks if y-p.y is less than epsilon which covers
// the round off
}
return false; // both these methods test for equality using epsilon,
// becuae we are dealing with
} // doubles, so roundof can occur
Также вы используете Math.abs(...)
неправильно. Он должен обходить оператор вычитания, а не каждую переменную.
Комментарии:
1. Когда я вызываю свои точки / облако в моем основном, он просто печатает первое добавленное мной значение, которое мне кажется странным
2. @user3777537: это не имеет абсолютно никакого отношения к,
toString()
и ваша строка toString работает правильно. Ваша проблема на самом деле в том, почему у вас есть только первое значение в вашем списке. Пожалуйста, улучшите свой вопрос.3. Я обновил его. Не могли бы вы, пожалуйста, взглянуть сейчас на то, почему он печатает только мое первое значение?
4. @user3777537: итак, вы не используете
java.awt.Point
, вместо этого вы используете свой собственный класс Point …. и использует ли он статические поля для каждого случая? Покажите класс точки. А что касается вашегоcontains(...)
метода — вот в чем может быть проблема!5. @user3777537: нет, я прав. Your equals ошибается по другой причине. Вы замыкаете его, если x1 == x2, он возвращает true независимо от y. Нехорошо.