感谢好心人士帮忙解答以下问题,最后能编出完整代码。感谢!!
都说两点确定一条直线,那么设计一个直线类Line,需要通过两个点Point对象来确定。Line类具体要求如下:
1)定义两个Point对象p1,p2;
2)写出有参构造方法,传递两个对象值给p1,p2
3)为p1,p2写出setters,和getters方法
4)为Line写出一个getLength方法求直线中两点的长度
5) 为Line写一个ToString方法,方法如下所示:
public String toString() { return "Line [p1=" + p1 + ", p2=" + p2 + "]"; }
在Main类的main方法中,定义一个Line数组,数组长度通过键盘给出,然后通过键盘为每线段的两个Point对象的坐标赋值,并生成相应Line对象放入数组中,循环数组,输出每条直线的信息,以及两个点之间的距离。
Point 类如下所示:
public class Point {
private int x, y;// x,y为点的坐标
//求两点之间的距离
public double distance(Point p1) {
return Math.sqrt((p1.x -this.x)(p1.x -this.x)+(p1.y-this.y)(p1.y-this.y));
}
public Point(int x, int y) {
super();
this.x = x;
this.y = y;
}
public int getX() {
return x;
}
public void setX(int x) {
this.x = x;
}
public int getY() {
return y;
}
public void setY(int y) {
this.y = y;
}
public Point() {
super();
x = y =0;
}
@Override
public String toString() {
return "Point [x=" + x + ", y=" + y + "]";
}
}
输入格式:
第一行输入数组的长度n 每一行输入一个Line对象的两个点对象的 x y的坐标,中间用空格隔开
输出格式:
循环输出,输出直线的信息,以及每条直线的两个点的距离,保留一位小数。
输入样例:
在这里给出一组输入。例如:
2
0 0 2 3
1 3 2 5
输出样例:
在这里给出相应的输出。例如:
Line [p1=Point [x=0, y=0], p2=Point [x=2, y=3]]
此线段的长度为:3.6
Line [p1=Point [x=1, y=3], p2=Point [x=2, y=5]]
此线段的长度为:2.2
Java中关于子类继承的一个实例问题(关于两点确定一条直线),感谢好心人士帮忙回答
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- qq_51536474 2021-01-04 19:15关注
import java.util.Scanner; public class Main { public static void main(String[] args) { // TODO Auto-generated method stub Scanner iScanner=new Scanner(System.in); line line1=new line(); int b=iScanner.nextInt(); double[] a=new double[b]; int z[][]=new int[b][4]; for (int i = 0; i < z.length; i++) { for (int j = 0; j < z[i].length; j++) { int c=iScanner.nextInt(); z[i][j]=c; } } for (int i = 0; i < z.length; i++) { line1.p1=new Point(z[i][0],z[i][1]); line1.p2=new Point(z[i][2],z[i][3]); a[i]=line1.getLength(line1.p1,line1.p2 ); System.out.println(line1.toString()); System.out.printf("此线段的长度为:%.1f",a[i]); System.out.println(); } } } class Point { int x;// x,y为点的坐标 int y; //求两点之间的距离 Point p1,p2; public double distance(Point p1) { return Math.sqrt((p1.x -this.x)*(p1.x -this.x)+(p1.y-this.y)*(p1.y-this.y)); } public Point(int x, int y) { super(); this.x = x; this.y = y; } public int getX() { return x; } public void setX(int x) { this.x = x; } public int getY() { return y; } @Override public String toString() { return "Point [x=" + x + ", y=" + y + "]"; } public void setY(int y) { this.y = y; } public Point() { super(); x = y =0; } } class line extends Point{ public double getLength(Point p1,Point p2) { return Math.sqrt((p1.x -p2.x)*(p1.x -p2.x)+(p1.y-p2.y)*(p1.y-p2.y)); } public String toString() { return "Line [p1=" + p1 + ", p2=" + p2 + "]"; } }
PTA以通过,欢迎关注我嗷~
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥15 请问有用MZmine处理 “Waters SYNAPT G2-Si QTOF质谱仪在MSE模式下采集的非靶向数据” 的分析教程吗
- ¥50 opencv4nodejs 如何安装
- ¥15 adb push异常 adb: error: 1409-byte write failed: Invalid argument
- ¥15 nginx反向代理获取ip,java获取真实ip
- ¥15 eda:门禁系统设计
- ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
- ¥15 376.1电表主站通信协议下发指令全被否认问题
- ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
- ¥15 复杂网络,变滞后传递熵,FDA
- ¥20 csv格式数据集预处理及模型选择