首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读以下说明和Java程序,填充程序中的空缺,将解答填入答题纸的对应栏内。 【说明】 下面的程序用来计算并寻找平面坐标系中给定点中最近的点对(若存在多对,则输出其中的一对即可)。程序运行时,先输入点的个数和一组互异的点的坐标,通过计算每对点
阅读以下说明和Java程序,填充程序中的空缺,将解答填入答题纸的对应栏内。 【说明】 下面的程序用来计算并寻找平面坐标系中给定点中最近的点对(若存在多对,则输出其中的一对即可)。程序运行时,先输入点的个数和一组互异的点的坐标,通过计算每对点
admin
2013-07-03
63
问题
阅读以下说明和Java程序,填充程序中的空缺,将解答填入答题纸的对应栏内。
【说明】
下面的程序用来计算并寻找平面坐标系中给定点中最近的点对(若存在多对,则输出其中的一对即可)。程序运行时,先输入点的个数和一组互异的点的坐标,通过计算每对点之间的距离,从而确定出距离最近的点对。例如,在下图所示的8个点中,点(1,1)与(2,0.5)是问距最近的点对。
[Java代码】
import java.util.Scanner;
class GPoint
{
private double x,y;
public void setX(aouble x) {this.x:x;}
public void setY(double y) {this.y=y;}
public double getX() {return this.x;}
public double getY() {return this.y;
}
class FindNearestPoints{
public static void main(String[]args){
Scanner input=new Scanner(System.in);
System.out.print(”输入点的个数:”);
int numberOfPoints=input.nextInt():
(1)
points=new GPoint[numberOfPoints]; //创建保存点坐标的数组
System.out.print(”请输入”+numberOfPoints+”个点的坐标”);
for(int i=0;i<points.1ength;i++){
points
=
(2)
;
points
.setX(input.nextDouble());
points
.setY(input.nextDouble());
}
FindNearestPoints fnp=new FindNearestPoints():
int p1=0,p2:1; //p1和p2用于表示距离最近的点对在数组中的下标
double shortestDistance=fnp.getDistance(points[p1],points[p2]);
//计算每一对点之间的距离
for(int i=0;i<:points.1ength;i++)
{
for(intj=1+1;j<
(3)
;J++)
{
double tmpDistance=fnp.
(4)
;
//计算两点间的距离
if(
(5)
)
{
p1=i;
p2=j;
shortestDistance=tmpDistance;
}
}
}
System.out.println(”距离最近的点对是(”+
points[p1].getX()+”,”+points[p1].getY()+”)和(”+
points[p2].getX()+”,”+points[p2].getY()+”)”);
}
public double getDistance(GPoint ptl,GPoint pt2)
{
retum Math.sqrt((pt2.getX() - pt1.getX())*(pt2.getX() - pt11getX())
+(pt2.getY() - pt1.getY())*(pt2.getY() - pt1.getY());
}
}
选项
答案
(1)GPoint[] (2)new GPoint[] (3)points.length (4)getDistance(points[i],points[j]) (5)shortestDistance>tmpDistance
解析
本题考查考生使用Java语青进行面向对象程序设计的能力。首先要理解清楚题目中有关最近点对的概念和计算方法,然后阅读程序以实现该功能。
(1)处显示创建保存点坐标的数组。这里的new运算符用于开辟数组空间,其语法规则为:new类型[初值]。(1)处需要填入一类型修饰符,因此应填入GPoint。类似的思路,(2)处考查Java语言中用new初始化数组,应填入new GPoint[]。
根据程序段中的注释,(3)和(4)处实现计算每一对点之间的距离。(3)处为循环控制变量,因为要计算所有对点间的距离,因此应填入points.1ength。(4)处应调用computeDistance类的distance函数计算每一对点points
和points[j]之间的距离,因此应填入getDistance(points
,points[j])。
(5)处应填入一个判断条件,以输出距离最小的点对。这可通过比较shortestDistance和tmpDistance来实现。因此,(5)处应填入shortestDistance>tmpDistance。
转载请注明原文地址:https://kaotiyun.com/show/rnjZ777K
本试题收录于:
程序员下午应用技术考试题库软考初级分类
0
程序员下午应用技术考试
软考初级
相关试题推荐
在Word2010中,要对设定好纸张大小的文档进行每页行数和每行字数调整,可通过页面设置对话框中的()命令进行设置。
在Excel中,若A1单元格中的内容为“全国计算机技术与软件专业技术资格(水平)考试”,在A2单元格中输入函数=LEFT(A1,2),则A2单元格显示的内容是______。
在Word编辑状态下,有些英文单词或汉字下面会自动加上红色或绿色的波浪型细下划线。以下叙述中,“波浪型细下划线(44)”是错误的。
假设100个数据的平均值为82.31,其中有10个数据又发生了如下增减变化:+3.52,+2.87,-4.13,+5.34,-2.87,+2.50,-3.52,+4.23,-5.04,+0.10,则新的平均值变为(26)。
计算机受病毒感染主要是______。
四位二进制数(从0000到1111)中,不含连续三位相同数字的数共有(4)个。
《信息技术汉字字型要求和检测方法》(GB/T11460一一2009)属于______。
小张为本企业录入一篇领导讲话文稿。文稿中引用了该企业2008年的销售额和各产品的利润等数据。小张考虑到目前是2010年,从信息的实效性出发,决定对文稿中的这部分内容进行处理,则______做法最为恰当。
甲和乙用如下图的两个转盘做游戏,游戏规则如下:分别旋转两个转盘,当两个转盘所转到的数字之积为奇数时,甲得2分;当所转到的数字之积为偶数时,乙得1分,则这游戏规则______。
资源记录文件位于/var/named目录下。这个目录是在以上的(1)文件中定义的。从备选选项中选择(6)~(10)处的解答。在问题4的named.abc.net文件中,出现了5种类型的记录。其中SOA是(6),NS是(7),MX是(8),A是
随机试题
贯彻企业的质量方针,每个职工要(),在工作中不断进行改善,努力提高产品和工作服务质量。
常用放射性药物与普通药物的相互作用下列哪项正确
关于左心室肥大,以下说法错误的是
某煤矿采煤工作面因自然发火而封闭,并对该工作面采用了均压通风和黄泥灌浆等措施进行处理。1年后,经过连续2个月取样化验分析,火区内氧气浓度为4%~5%,一氧化碳浓度在0.001%以下,没有检测到乙烯和乙炔,火区的出水温度为22~24℃,则该火区(
不属于业主风险管理措施的选项有()。
我国西北干旱半干旱区油气资源丰富。“西气东输”的主要原因是()。
从所给的四个选项中,选择最合适的一个填入问号处,使之呈现一定的规律性。
君士坦丁
简述认知一评价理论,并说说该理论的发展意义。【华南师范大学2014;上海师范大学2014;曲阜师范大学2011】
在考生文件夹下有一个工程文件sjt5.vbp。程序运行时,单击“装入数据”按钮,则从考生文件夹下的in5.txt文件中读入所有城市名称和距离,城市名称按顺序添加到列表框List1中,距离放到数组a中;当选中列表框中的一个城市时,它的距离就在Text1中显示
最新回复
(
0
)