试题D:路径
创始人
2024-06-02 14:36:09
0

试题D:路径

文章目录

  • 试题D:路径
  • 一、前置知识
  • 二、分析
    • 1、数据分析
    • 2、过程分析
  • 三、代码
  • 四、参考材料

题目描述

​ 小蓝学习了最短路径之后特别高兴,他定义了一个特别的图,希望找到图中的最短路径。小蓝的图由2021 个结点组成,依次编号1 至2021。

对于两个不同的结点a, b,如果a 和b 的差的绝对值大于21,则两个结点之间没有边相连;如果a 和b 的差的绝对值小于等于21,则两个点之间有一条长度为a 和b 的最小公倍数的无向边相连
​ 例如:结点1 和结点23 之间没有边相连;结点3 和结点24 之间有一条无向边,长度为24;
结点15 和结点25 之间有一条无向边,长度为75。
​ 请计算,结点1 和结点2021 之间的最短路径长度是多少。
​ 提示:建议使用计算机编程解决问题。

解析:



一、前置知识

问题1:怎么求两个数a,b的最小公倍数呢?

答:【公式】a,b最小公倍数=a×b/a,b的最大公因数a,b最小公倍数 = a \times b / a,b的最大公因数a,b最小公倍数=a×b/a,b的最大公因数.

问题2:怎么求最大公因数呢?

答:辗转相除法

public static int gcd(int a,int b){return b==0?a:gcd(b,a%b);
}

问题3:阈值的选取

答:这一步很重要,下午调试了很久都是因为阈值没选好。阈值不能很大,因为这样可能会使扩展部分的加法查出long型范围;阈值不能太小,太小导致答案在阈值外面。

问题4:long型和Long型的区别

int转long型自然转换,int转Long型强制转换。




二、分析

1、数据分析

  • 0 < i 和 j 两个节点之间的差的绝对值 <22,distance[i][j] =a,b最小公倍数
  • i 和 j 两个节点之间的差的绝对值==0,distance[i][j] =0
  • i 和 j 两个节点之间的差的绝对值 > 21,distance[i][j] = 阈值,阈值十分重要,本次屡次在这犯错

2、过程分析

​ 在图中求一个点到另一个点的距离,可以使用Dijkstra和Floyd方法。可以使用Floyd方法是因为本题是填空题,时间复杂度不重要。

​ 关于Dijkstra和Floyd方法可以查看Dijkstra和Floyd




三、代码

1、Dijkstra代码

public class ExaminationD_Dijkstra {//求解最大公因数public static long gcd(long a,long b){return b==0?a:gcd(b,a%b);}//求解a,b的最小公倍数public static long lcm(long a,long b){return a*b/gcd(a,b);}public static long[] dijkstra(long[][] distance,int n,int origin){//辅助数组boolean[] used = new boolean[n];long[] minDis = new long[n];int pathIndex = origin-1;//初始化数组for (int i = 0; i < n; i++) {minDis[i] = distance[origin-1][i];}used[origin-1] = true;for (int i = 1; i < n; i++) {long min = Long.MAX_VALUE;//选取部分for (int j = 0; j < n; j++) {if (!used[j]&&minDis[j]//System.out.println(String.format("变化前minDis[%d]=%d,min=%d",j,minDis[j],min));min = minDis[j];//System.out.println(String.format("变化后minDis[%d]=%d,min=%d",j,minDis[j],min));pathIndex = j;}}used[pathIndex]= true;//扩展部分for (int k = 0; k < n; k++) {if (distance[pathIndex][k]!=Long.MAX_VALUE) {//选取合适的阈值使答案在这个范围又要使下面的加法不差过long范围if (minDis[pathIndex]+distance[pathIndex][k]minDis[k] = minDis[pathIndex] + distance[pathIndex][k];System.out.println(String.format("扩展minDisk[%d]=%d",k,minDis[k]));}}}}return minDis;}public static void main(String[] args) {int n = 2021;long[][] dis = new long[n][n];for (int i = 0; i < n; i++) {for (int j = 0; j < n; j++) {if (Math.abs(i-j)<=21&&Math.abs(i-j)>0) {dis[i][j] = dis[j][i] = lcm(i+1,j+1);}else if(i==j){dis[i][j] = 0;//在扩展部分可能会加上去}else if(Math.abs(i-j)>21){dis[i][j] = Long.MAX_VALUE;}}}long[] res = dijkstra(dis, n, 1);System.out.println(res[n-1]);}
}

2、Floyd代码

//麻烦的是怎么设定一个阈值
public class ExaminationD_Floyd {//求解最大公因数public static long gcd(long a,long b){return b==0?a:gcd(b,a%b);}//求解a,b的最小公倍数public static long lcm(long a,long b){return a*b/gcd(a,b);}public static long[][] floyd(long[][] distance,int n,int origin){for (int k = 0; k for (int i = 0; i < n; i++) {for (int j = 0; j < n; j++) {if (distance[k][j]!=99999999L) {//设定阈值使小于阈值的两个数相加不超过long范围if (distance[i][k]+distance[k][j]distance[i][j] = distance[i][k]+distance[k][j];}}}}}return distance;}public static void main(String[] args) {int n = 2021;long[][] dis = new long[n][n];for (int i = 0; i < n; i++) {for (int j = 0; j < n; j++) {if (Math.abs(i-j)<=21&&Math.abs(i-j)>0) {dis[i][j] = dis[j][i] = lcm(i+1,j+1);}else if(i==j){dis[i][j] = 0;}else if(Math.abs(i-j)>21){dis[i][j] = 99999999L;}}}long res[][] = floyd(dis,n,1);System.out.println(res[0][n-1]);}
}




四、参考材料

蓝桥杯2021初赛 路径 Java

[2]2021蓝桥杯 java路径

相关内容

热门资讯

安卓系统苹果手机识别,跨界融合... 你知道吗?在科技飞速发展的今天,手机已经成为了我们生活中不可或缺的一部分。而说到手机,安卓系统和苹果...
harmonyos系统是不是安... 亲爱的读者,你是否曾好奇过HarmonyOS系统与安卓系统之间的关系?是不是安卓的“亲戚”?今天,就...
手机怎么装系统安卓,安卓系统安... 手机卡顿了?想给安卓系统来个大变身?别急,跟着我一步步来,保证让你的手机焕然一新!一、准备工作在开始...
安卓Linux系统内网穿透,A... 你有没有想过,你的安卓手机里那些看似普通的APP,其实可能正在悄悄地帮你打通网络世界的任督二脉呢?没...
win怎么安装安卓系统,Win... 亲爱的读者,你是不是对Win系统上的安卓应用垂涎已久,但又苦于不知道如何安装安卓系统呢?别急,今天我...
升级小米平板安卓系统,畅享全新... 你有没有发现,你的小米平板用久了,是不是感觉有点卡呢?别急,今天就来教你怎么给它来个系统升级,让它焕...
捷豹安卓系统车载,捷豹安卓系统... 哇,你有没有想过,当你的手机和汽车融为一体,会是怎样的体验呢?想象你正驾驶着你的捷豹,车窗外的风景如...
安卓1到10系统,安卓1.0至... 你有没有想过,手机里的安卓系统就像是我们生活中的好朋友,从青涩的少年成长为稳重的青年呢?从安卓1.0...
安卓8.0停用系统应用,提升使... 你知道吗?最近安卓系统又来了一次大动作,那就是安卓8.0系统开始停用一些系统应用了。这可真是让人有点...
安卓系统修改mtu值,轻松提升... 你有没有想过,你的安卓手机其实是个小小的电脑呢?它里面藏着许多可以自定义的秘密功能,就像修改MTU值...
安卓平板改window系统,探... 你有没有想过,你的安卓平板其实可以摇身一变,变成一个Windows系统的电脑呢?没错,就是那种可以运...
时空猎人安卓苹果系统,探索无尽... 你知道吗?最近在手机游戏圈里,有一款叫做《时空猎人》的游戏可是火得一塌糊涂呢!不管是安卓用户还是苹果...
安卓9.0系统的电视,新一代电... 亲爱的读者们,你是否也像我一样,对科技新玩意儿充满好奇?今天,我要和你聊聊一个让人眼前一亮的话题——...
小pc安装安卓系统,轻松安装安... 你有没有想过,你的小PC也能变身成为安卓系统的超级玩家呢?没错,就是那个平时默默无闻的小家伙,现在也...
高通备份安卓系统,全方位数据安... 你知道吗?在这个科技飞速发展的时代,手机备份可是个不得不提的话题。尤其是对于安卓用户来说,选择一个靠...
谷歌安卓系统有多少,从诞生到全... 你有没有想过,那个无处不在的谷歌安卓系统,究竟在全球有多少用户呢?它就像一个神秘的数字,每天都在悄悄...
fc黄金传说安卓系统,畅享复古... 你有没有听说最近安卓系统上的一款超酷的游戏——《FC黄金传说》?这款游戏可是让不少玩家都沉迷其中,今...
变小的我安卓系统,安卓系统演变... 你有没有发现,最近你的手机好像变轻了?没错,说的就是你,那个陪伴你多年的安卓系统。它悄无声息地进行了...
vivo安卓系统小彩蛋,体验科... 你知道吗?在vivo的安卓系统中,竟然隐藏着一些超有趣的小彩蛋!这些小彩蛋就像是在手机里埋下的宝藏,...
安卓系统如何强制重启,安卓系统... 手机突然卡壳了,是不是又该给它来个“大保健”了?没错,今天就来聊聊安卓系统如何强制重启。别小看这个看...