Java、MyPoint类

在这里插入图片描述


—————————————————————
                MyPoint
—————————————————————
-x: double
-y: double
—————————————————————
+MyPoint()
+MyPoint(x: double, y: double)
+distance(point: MyPoint): double
+distance(x: double, y: double): double
+getX(): double
+getY(): double
—————————————————————


package pack2;

public class MyPoint {
	private double x, y;	//x、y坐标
	
	/**带(0,0)的无参构造方法*/
	public MyPoint() {
		this(0, 0);
	}

	/**带(x,y)的构造方法*/
	public MyPoint(double x, double y) {
		this.x = x;
		this.y = y;
	}

	/**返回该点到指定对象点的距离*/
	public double distance(MyPoint point) {
		return Math.sqrt(Math.pow(x - point.getX(), 2) + Math.pow(y - point.getY(), 2));
	}
	
	/**返回该点到指定坐标的距离*/
	public double distance(double x, double y) {
		return Math.sqrt(Math.pow(x - this.x, 2) + Math.pow(y - this.y, 2));
	}
	
	/**返回x坐标*/
	public double getX() {
		return x;
	}

	/**返回y坐标*/
	public double getY() {
		return y;
	}

//——————————————————————————————————————————————————
	public static void main(String[] args) {
 		System.out.println("The distance is " + new MyPoint().distance(new MyPoint(10, 
                 30.5)));
	}

}


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Triangle2D是一个表示二维平面上三角形的,具体实现如下: ```java public class Triangle2D { private MyPoint p1, p2, p3; // 三个顶 // 构造函数 public Triangle2D(double x1, double y1, double x2, double y2, double x3, double y3) { p1 = new MyPoint(x1, y1); p2 = new MyPoint(x2, y2); p3 = new MyPoint(x3, y3); } // 计算周长 public double getPerimeter() { double side1 = p1.distance(p2); double side2 = p2.distance(p3); double side3 = p3.distance(p1); return side1 + side2 + side3; } // 计算面积 public double getArea() { double s = getPerimeter() / 2; double side1 = p1.distance(p2); double side2 = p2.distance(p3); double side3 = p3.distance(p1); return Math.sqrt(s * (s - side1) * (s - side2) * (s - side3)); } // 判断是否在三角形内部 public boolean contains(MyPoint point) { double x = point.getX(); double y = point.getY(); double x1 = p1.getX(); double y1 = p1.getY(); double x2 = p2.getX(); double y2 = p2.getY(); double x3 = p3.getX(); double y3 = p3.getY(); double alpha = ((y2 - y3)*(x - x3) + (x3 - x2)*(y - y3)) / ((y2 - y3)*(x1 - x3) + (x3 - x2)*(y1 - y3)); double beta = ((y3 - y1)*(x - x3) + (x1 - x3)*(y - y3)) / ((y2 - y3)*(x1 - x3) + (x3 - x2)*(y1 - y3)); double gamma = 1.0 - alpha - beta; return alpha > 0 && beta > 0 && gamma > 0; } // 判断两个三角形是否相等 public boolean equals(Triangle2D t) { double x1 = p1.getX(); double y1 = p1.getY(); double x2 = p2.getX(); double y2 = p2.getY(); double x3 = p3.getX(); double y3 = p3.getY(); double tx1 = t.getP1().getX(); double ty1 = t.getP1().getY(); double tx2 = t.getP2().getX(); double ty2 = t.getP2().getY(); double tx3 = t.getP3().getX(); double ty3 = t.getP3().getY(); return x1 == tx1 && y1 == ty1 && x2 == tx2 && y2 == ty2 && x3 == tx3 && y3 == ty3; } // 获取三个顶 public MyPoint getP1() { return p1; } public MyPoint getP2() { return p2; } public MyPoint getP3() { return p3; } } ``` 在这个中,我们实现了计算三角形周长和面积的方法,并且实现了判断一个是否在三角形内部的方法。我们还实现了判断两个三角形是否相等的方法,以及获取三个顶方法

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值