蛮力法实现最近对问题
来源:互联网 发布:东北大学网络教育 证书 编辑:程序博客网 时间:2024/04/30 20:00
package test;import java.text.DecimalFormat;import java.util.Scanner;public class Manlifa {public static int n;/* * 注,此处若没有为数组进行初始化则会出现空指针异常,即仅仅声明了数组x和y, * 声明了数组,但是并没有为他们分配相应的内存空间,此时,他们仅仅是一个地址罢了 */public static double x[] = new double[100];public static double y[] = new double[100];public Manlifa() {}public static void choose() {int i;int j;int indexi = 0;int indexj = 0;double mindistance = (double) 800;double d;DecimalFormat df = new DecimalFormat("0.00");for (i = 0; i < n - 1; i++)for (j = i + 1; j < n; j++) {d = (x[i] - x[j]) * (x[i] - x[j]) + (y[i] - y[j]) * (y[i] - y[j]);if (d < mindistance) {mindistance = d;indexi = i;indexj = j;}}System.out.println("距离最短的两个点是," + "(" + x[indexi] + "," + y[indexi] + ")" + "(" + x[indexj] + "," + y[indexj] + ")");System.out.printf("最短距离为:");System.out.printf(df.format(Math.sqrt(mindistance)));}public static void main(String arg[]) {int ch = 0;int i = 0;System.out.println("请输入若干个点:");Scanner read = new Scanner(System.in);Manlifa m = new Manlifa();while (ch != 1) {x[i] = read.nextDouble();y[i] = read.nextDouble();ch = read.nextInt();n++;i++;}n = n - 1;m.choose();}}
0 0
- 蛮力法实现最近对问题
- 蛮力法最近对问题
- 蛮力法之最近对问题(C实现)
- 分治法实现最近对问题
- 最近点对问题
- 最近点对问题
- 最近点对问题
- 最近点对问题
- 最近点对问题
- 最近对问题
- 最近点对问题
- 最近点对问题
- 最近点对问题
- 最近点对问题
- 最近点对问题
- 最近点对问题
- 最近点对问题
- 最近点对问题
- 函数概述、return关键字、函数重载
- 使用VideoView自定义一个播放器控件
- android 光线传感器 light sensor的使用
- Android-Widget桌面小组件
- 去哪网面试问题及答案9-22
- 蛮力法实现最近对问题
- 20分钟快速了解redis
- Docke 1.12 基础篇:48条命令(4)
- 格式化输出json数据
- 安装CentOS6.5
- jquery的$().each,$.each的区别
- solr入门(基础程序)
- UI界面-UILabel
- Maximum Subsequence Sum