完成如下
package level02
object Class05 {
class Point(var x: Double, var y: Double) {
// 实现 whereAmI 方法:判断点所在的象限或坐标轴
def whereAmI(): String = {
if (x == 0 && y == 0) "原点"
else if (x == 0) "Y轴上"
else if (y == 0) "X轴上"
else if (x > 0 && y > 0) "第一象限"
else if (x < 0 && y > 0) "第二象限"
else if (x < 0 && y < 0) "第三象限"
else "第四象限"
}
def getDist(): Double = {
Math.sqrt(x * x + y * y)
}
def fromPoint(other: Point): Double = {
val dx = other.x - x
val dy = other.y - y
Math.sqrt(dx * dx + dy * dy)
}
override def toString: String = s"Point($x, $y)"
// 实现 equals 方法:判断两个 Point 是否坐标相同
override def equals(obj: Any): Boolean = {
obj match {
case p: Point => p.x == this.x && p.y == this.y
case _ => false
}
}
}
// 作业:英雄王陪金(这里实现 LabelPoint 类,继承 Point 并添加标签属性)
class LabelPoint(var label: String, x: Double, y: Double) extends Point(x, y) {
override def toString: String = s"LabelPoint($label, $x, $y)"
}
def main(args: Array[String]): Unit = {
// 测试
val p1 = new Point(1.0, 1.0)
val p2 = new Point(1.0, 1.0)
println(p1.whereAmI())
println(p1.getDist())
println(p1.fromPoint(p2))
println(p1 == p2)
// 测试 LabelPoint
val lp = new LabelPoint("原点附近", 0.5, 0.5)
println(lp.whereAmI())
println(lp.getDist())
}
}
输出结果
whereAmI方法:根据点的横纵坐标(x、y)判断其位于原点、坐标轴或某个象限。equals方法:通过模式匹配判断传入的对象是否为Point类型,且横纵坐标与当前对象完全相同。LabelPoint类:继承Point类,添加label属性用于标识点,并重写toString方法以包含标签信息。main方法:补充了LabelPoint的测试逻辑,验证子类功能的同时也确保父类逻辑正常运行。