700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > 面向对象程序设计——Java语言 第3周编程题 查找里程(10分)

面向对象程序设计——Java语言 第3周编程题 查找里程(10分)

时间:2022-10-16 15:27:13

相关推荐

面向对象程序设计——Java语言 第3周编程题 查找里程(10分)

面向对象程序设计——Java语言 第3周编程题 查找里程(10分)

题目内容

下图为国内主要城市之间的公路里程:

你的程序要读入这样的一张表,然后,根据输入的两个城市的名称,给出这两个城市之间的里程。

注意:任何两个城市之间的里程都已经给出,不需要计算经第三地中转。

注意:你并不需要去录入上图的数据,数据是在程序输入中给的。

输入格式

首先,你会读到若干个城市的名字。每个名字都只是一个英文单词,中间不含空格或其他符号。当读到名字为“###”(三个#号)时,表示城市名字输入结束,###并不是一个城市的名字。如果记读到的城市名字的数量为n。

然后,你会读到nxn的一个整数矩阵。第一行的每一个数字,表示上述城市名单中第一个城市依次到另一个城市之间的里程。表中同一个城市之间的里程为0。

最后,你会读到两个城市的名字。

输出格式

输出这两个城市之间的距离。

输入样例

HagzouHugzouJigxng ###01108708110809947089940Hagzou Jigxng

输出样例

708

解题思路

建立一个Distance类, 两地的距离用HashMap储存 , 因为出发地和目的地是两个key,所以建立数据结构

HashMap<String,HashMap<String,Integer> >Distance类主要有两个函数,set用来插入数据,query用来查询数据注意的一点是Java字符串判断不能使用==,这样判断的是两个字符串引用是否相同/是同一个字符串,而判断内容相等要用boolean String a.equals(String b)来判断

AC code

import java.util.ArrayList;import java.util.HashMap;import java.util.Scanner;public class Main {public static void main(String[] args) {Distance distance = new Distance();Scanner in = new Scanner(System.in);ArrayList<String> arr = new ArrayList<String>();String tmp = null;while(true) {tmp = in.next();if(tmp.equals("###")) {break;}arr.add(tmp);}for(int i=0;i<arr.size();i++) {HashMap<String,Integer> dis2city = new HashMap<String,Integer>();for(int j=0;j<arr.size();j++) {int dis = in.nextInt();dis2city.put(arr.get(j),dis);}distance.set(arr.get(i), dis2city);}String city1=null; String city2=null;city1 = in.next();city2 = in.next();System.out.println(distance.query(city1,city2));}}class Distance{private HashMap<String,HashMap<String,Integer> > mp = new HashMap<String,HashMap<String,Integer> >();public void set(String start,HashMap<String,Integer> hash) {mp.put(start, hash);}public int query(String city1,String city2) {return mp.get(city1).get(city2);}}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。