2015年
1. 实现一个Ciy 类,表示城市,该类中的域为仅有的两个私有实例变量(单精度浮点类型),
用来表示该城市的位置坐标,不提供任何构造器,该类仅有五个方法,分别是:
两个方法用来读取该城市的x坐标和y坐标,一个方法利用参数设定该城市的x坐标和y坐标,一个无参方法计算该城市与原点的距离 (单精度浮点类型),一个名复用的方法计算该城市与参数(单精度浮点类型) 表示的点的距离(单精度浮点类型);
要求 1⃣️City 类实现一个接口1,并且City 类中的五个方法都在1中声明。再实现一个用于测试的主类 TestCitv,在其2⃣️主方法中创建City 对象(位置可任意),并存储在一个数组中,3⃣️利用接口1定义一个引用指向该数组对象,4⃣️利用该引用访问有关方法计算该数组中每个城市与原点的距离和并输出:将该数组理解为旅行路线,计算从起点(数组中第0个元素)城市到终点城市(数组中第999 个元素)间的旅行路线长度并输出(所有距离的计算要求通过对 City 类中的方法调用完成)。写出这三个类型的实现代码。
interface in1{
public float getX();
public float getY();
public void setcity(float x,float y);
public float distance();
public float distance(float x, float y);
//1⃣️写出方法名即可
}
class City implements in1{
private float city_x=0;
private float city_y=0;
public float getX(){ return this.city_x;}
public float getY(){ return this.city_y;}
public void setcity(float x, float y){
this.city_x=x;
this.city_y=y;
}
public float distance(){
float dis;
dis=Math.sqrt(city_x*2+city_y*2);
return dis;}
public float distance(float x, float y){
float dis
dis=Math.sqrt(((city_x-x)*(city_x-x))+(((city_y-y)*(city_y-y)));
return dis;}
}
public class TestCity{
public static void main(String [] args){
City [] c=new City[1000];//创建city组
for(int i=0;i<c.length;i++){
c[i]=new City();
c[i].setcity(i,i+1); //对city进行初始化
}
in1 p=c;//一个指针
float ans1=0;
float ans2=0;
for(int i=0;i<p.length;i++){ //p.length使用引用
ans1+= p[i].dictance();
}
for(int i=1;i<p.length;i++){
ans2+=(p[i].distance(p[i-1].getX(),p[i-1].getY()));
}
System.out.println(ans1);
System.out.println(ans2);
}