翁凯 java 第二周,翁恺老师的Java作业,面向对象第三周

查找里程(10分)

题目内容:

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

b28541bfc8154505e716e125a2c83d2e.png

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

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

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

输入格式:

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

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

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

输出格式:

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

输入样例:

Hagzou Hugzou Jigxng ###

0 1108 708

1108 0 994

708 994 0

Hagzou Jigxng

输出样例:708

关于这道题的解释,本题中,老师给你的图片是没用的!图片是没用的!图片是没用的!即使你下载下来之后看到的也只是一堆马赛克。

重要的是输入样例!重要的是输入样例!重要的是输入样例!

仔细分析这个表可以帮你更好的理解整个程序:

Hagzou

Hugzou

Jigxng

0

1108

708

1108

0

994

708

994

0

第一行是城市,用ArrayList储存,

后面表示距离:

第一行指的是该城市到第一列城市的距离;

第二行指的是该城市到第二列城市的距离;

以此类推……

要看懂这个表才能理解程序,最好写下来。

如下是代码:

import java.util.ArrayList;

import java.util.Scanner;

public class Main {

public static void main(String[] args) {

Scanner in=new Scanner(System.in);

//创建容器用来储存城市名,不要数组,因为数组有上限

ArrayList cities=new ArrayList();

//死循环用来输入城市,表格上层已经做完

while(true)

{

String city=in.next();

if(city.equals("xxx")) //判断对象的内容是否相等用equals(),不要用 ==,

{ //== 是判断他们是否管理着同一个对象

break;

}//把条件写在 add前面,这样输入为 xxx 的时候,cities 就不会再继录入数据

cities.add(city);

}

//测试代码,看看读入正确

//System.out.println(cities.size());

//定义数组用来存储距离

int[][] span=new int[cities.size()][cities.size()];

for(int i=0;i

{

for(int j=0;j

{

span[i][j]=in.nextInt();

}

}//表格结束

//定义城市名称,读入两个城市(定义变量是为了让人看懂),实际写的时候可以不要,包括下面的判断

String city1=in.next();

String city2=in.next();

if(cities.contains(city1)&&cities.contains(city2))//判断在容器里面城市受否存在

{//contains()和equals()是一样的,都是检查内容

int i=cities.indexOf(city1);//这里的方法时参考了用户 Kahung_L 的代码,

int j=cities.indexOf(city2);//因为课上没有讲过获容器里面元素下标的方法

System.out.println(span[i][j]);

}

else

{

System.out.println("NOT FOUND");

}

//直接写成这样就行

//int a=cities.indexOf(in.next());

//int b=cities.indexOf(in.next());

//System.out.println(span[a][b]);

in.close();

}//mian函数结束

}//类结束

测试结果:

1.

c930eeb4e2935a3c4b5158089a8d28ff.png

2.

a975f4f712bd5f2aee79991ef5460eff.png

后言;我已经尽量把代码写的条理清晰。最开始执着于图片,下载下来之后发现图片看不清,看别人代码的时候一脸懵逼。所以写代码之前最重要的是分析,分析之后再去看代码会豁然开朗。

代码参考: @Kahung_L

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MOOC翁凯C语言期末考试是一项对学生在C语言编程方面的掌握程度进行综合评估的考试。在这次考试中,学生将会面对一系列与C语言相关的问题和编程题目。 首先,考试将会涉及C语言的基础知识,包括变量定义、运算符使用、流程控制和函数的使用等。学生需要对这些内容有清晰的理解和掌握,能够正确地应用于实际的编程问题中。 其次,考试还将要求学生能够分析和解决一些较为复杂的编程问题。这些问题可能涉及到数组、指针、结构体等高级数据结构和算法的使用。学生需要能够理解并正确应用这些概念,以解决给定的编程问题。 此外,考试可能会涉及一些C语言程序的输出结果预测和错误调试等内容。学生需要具备对C语言的程序执行过程有清晰的认识,能够正确预测程序输出结果,并有能力发现和纠正程序中的错误。 最后,考试还可能会包括一些编程题目,要求学生能够根据题目要求独立编写C语言程序。在这些题目中,学生需要展示自己的编程能力和解决问题的能力,用C语言实现要求的功能,并保证程序的正确性和健壮性。 综上所述,MOOC翁凯C语言期末考试是一次对学生在C语言编程方面的综合能力进行考察的考试。学生需要掌握C语言的基础知识,具备解决编程问题的能力,并能够独立完成一定的编程任务。该考试将帮助学生提升在C语言编程方面的能力,并为将来在计算机编程领域的学习和工作奠定坚实的基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值