AJPFX:求两个城市之间的距离
键盘录入多个城市: 城市1,城市2,城市3 以 ### 结束输出
然后再键盘录入各个城市之间的距离: 格式如下:
0,12,45
12,0,22
45,22,0
###
然后按照输入的两个城市,求得两个城市之间的距离:城市1 城市2
代码如下:
package com.johnson.test;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map.Entry;
import java.util.Scanner;
import java.util.Set;
public class Test3 {
/**
* @param args
*/
public static void main(String[] args) {
//存储两个城市的字符串 如 : 长沙 武汉
ArrayList<String> list = new ArrayList<String>();
//存储两个城市的字符串为键,距离为值 如 : 长沙 武汉,22
HashMap<String,Integer> cityDistance = new HashMap<String, Integer>();
Scanner sc = new Scanner(System.in);
System.out.println("请输入格式如下:城市1 城市2 城市3 ###");
String line;
while(true){
line = sc.nextLine();
if(line.endsWith("###")){
break;
}else{
System.out.println("请重输入:格式如下:城市1 城市2 城市3 ###");
}
}
//去除字符串后面的###号
line = line.substring(0,line.length()-3);
//将所有可能的城市组合存储在集合中
String[] arr = line.split(" ");
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr.length; j++) {
list.add(arr[i]+" "+arr[j]);
}
}
System.out.println("请输入城市之间的距离:格式如下:距离1 距离2 距离3");
String disString ;
//将list集合中的所有城市组合与输入的距离进行匹配,并存入到map集合中
int i = 0;
while(true){
disString = sc.nextLine();
if(disString.endsWith("###")){
break;
}else{
String[] dis = disString.split(" ");
for (int j = 0; j < dis.length; j++) {
//cityDistance.put(arr[i]+tm.get(arr[i]), Integer.parseInt(dis[j]));
cityDistance.put(list.get(i), Integer.parseInt(dis[j]));
i++;
}
}
}
//System.out.println(cityDistance);
System.out.println("请输入两个城市,格式:城市1 城市2");
b:for(;;){
String input = sc.nextLine();
if(input.equals("quit")){
break;
}
//遍历集合,查找是否存在键盘录入的两个城市
Set<Entry<String, Integer>> entrySet = cityDistance.entrySet();
a:for (Entry<String, Integer> en : entrySet) {
String key = en.getKey();
//如果存在,输出距离
if(input.equals(key)){
System.out.println(en.getValue());
break b;
} else{
//System.out.println("找不到距离");
continue a;
}
}
//如果遍历完之后,没有找到,则输出找不到距离
System.out.println("找不到距离");
}
}
}
AJPFX:求两个城市之间的距离的更多相关文章
- 高德地图 API 计算两个城市之间的距离
1. 目前在项目中,遇到一个需求不会做,就是要计算两个城市之间的距离,而这两个城市的输入是可变的,如果要使用数据库来先存储两地之间的距离,调用的时候再来调用,那么存数据的时候,要哭的,因为光是省级区域 ...
- 设计一个Mypoint类,求两个点之间的距离
package Test; public class test6 { public static void main(String[] args) { // TODO Auto-generated m ...
- IOS 计算两个经纬度之间的距离
IOS 计算两个经纬度之间的距离 一 丶 -(double)distanceBetweenOrderBy:(double) lat1 :(double) lat2 :(double) lng1 :(d ...
- js 求两个日期之间相差天数
//求两个日期之间的相差天数 function daysBetween(DateOne, DateTwo) { var OneMonth = DateOne.substring(5, DateOne. ...
- java如何计算两个经纬度之间的距离?
/*计算两个经纬度之间的距离 结果单位:米 */public static double getDistance(String lat1Str, String lng1Str, String lat2 ...
- PHP 求两个日期之间相差的天数、月数
<?php /** * 求两个日期之间相差的天数 * (针对1970年1月1日之后,求之前可以采用泰勒公式) * @param string $day1 * @param string $day ...
- Frogger POJ - 2253(求两个石头之间”所有通路中最长边中“的最小边)
题意 题目主要说的是,有两只青蛙,在两个石头上,他们之间也有一些石头,一只青蛙要想到达另一只青蛙所在地方,必须跳在石头上.题目中给出了两只青蛙的初始位置,以及剩余石头的位置,问一只青蛙到达另一只青 ...
- JavaScript求两个数字之间所有数字的和
这是在fcc上的中级算法中的第一题,拉出来的原因并不是因为有什么好说的,而是我刚看时以为是求两个数字的和, 很显然错了.我感觉自己的文字理解能力被严重鄙视了- -.故拉出来折腾折腾. 要求: 给你一个 ...
- PHP MYSQL 搜索周边坐标,并计算两个点之间的距离
搜索附近地点,例如,坐标(39.91, 116.37)附近500米内的人,首先算出“给定坐标附近500米”这个范围的坐标范围. 虽然它是个圆,但我们可以先求出该圆的外接正方形,然后拿正方形的经纬度范围 ...
随机推荐
- 超全!整理常用的iOS第三方资源(转)
超全!整理常用的iOS第三方资源 一:第三方插件 1:基于响应式编程思想的oc 地址:https://github.com/ReactiveCocoa/ReactiveCocoa 2:hud提示框 地 ...
- I2S
音频数据传输而制定: Inter—IC Sound : 单线 时钟和数据一条线,时分复用: 标准的I2S总线电缆是由3根串行导线组成的:1根是时分多路复用(简称TDM)数据线:1根是字选择线:1根是时 ...
- php基础篇:echo 与 print 的区别
在实际使用中, print 和 echo 两者的功能几乎是完全一样.可以这么说,凡是有一个可以使用的地方,另一个也可以使用.但是,两者之间也还是一个非常重要的区别:在 echo 函数中,可以同时输出多 ...
- get all sites under IIS
https://stackoverflow.com/questions/2555668/how-to-programmatically-get-sites-list-and-virtual-dirs- ...
- Oracle备份与恢复:冷备份恢复
模拟数据库数据文件丢失的情况下,通过丢失之前的数据文件物理备份做恢复: 说明:数据文件丢失前一刻的所有归档日志都存在. 环境:oracle10g +rhel5 1.关闭数据库,copy system0 ...
- HTTPS站点搭建教程:Win7/Windows Server 2008R2
本文将由笔者为各位读者介绍在win7/windows server 2008R2环境下使用SSL加密协议建立WWW站点的全过程:https SSL证书安装的搭建以及本地测试环境. 要想成功架设SSL安 ...
- java nio的一个严重BUG
java nio的一个严重BUG Posted on 2009-09-28 19:27 dennis 阅读(4588) 评论(5) 编辑 收藏 所属分类: java .源码解读 这个BU ...
- 书写优雅的shell脚本(插曲)- ed编辑器
今天发现了一个灰常好用的unix/linux文本行编辑器:ed,对于进行面向行的文本编辑工作她真是太棒了,比vi操作简单.方便.功能强大.感兴趣的同仁可以尝试一下!
- 汇编环境的搭建(windows 10 + debug)
1. debug.exe 安装 win10 版本过高,不再提供 debug.exe,甚至从别处获取的 debug.exe 的也无法运行. 汇编语言学习所需的各种执行文件(debug.exe.link. ...
- SPOJ:Help BTW(二分)
BTW wants to buy a gift for her BF and plans to buy an integer array. Generally Integer arrays are c ...