试题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路径

相关内容

热门资讯

简述rfid系统的组成-RFI... 嘿,你知道RFID系统是怎么一回事吗?别急,我来给你扒一扒这背后的秘密!首先,RFID系统可不只是一...
winpe启动盘下载-电脑崩溃... 嘿,朋友们!你们有没有经历过那种电脑突然崩溃,所有数据都像被黑洞吞噬一样的绝望感?别担心,今天我要给...
图书室图书登记表范文-学校图书... 哎呀,说到我们学校的图书室,那可真是个宝藏地儿!每次走进去,我都觉得自己像是走进了一个巨大的秘密花园...
windows7 系统配置-W... 嘿,说到Windows7,我这心里就五味杂陈啊!记得那会儿,刚买回新电脑,第一件事就是得装个系统,对...
数字化管理系统:开启高效管理之... 数字化管理系统就像一把魔法钥匙,打开了高效管理的大门。想象一下,你的工作和生活都被各种琐事缠绕,突然...
720文档恢复-720 文档突... 天啊,谁能告诉我,为什么我的720文档突然不见了?!那可是我过去一年的心血啊,所有的报告、笔记、还有...
朝阳市第四人民医院:人情味与温... 在朝阳市的喧嚣中,有一处地方总是显得格外宁静,那就是我们的朝阳市第四人民医院。这里不仅仅是治病救人的...
深入解析ubuntu操作系统-... 嘿,大家好!今天我要聊聊那个让我的电脑变得超级酷炫的东西——Ubuntu操作系统!没错,就是这个神奇...
省电模式下载安装-手机电量危机... 嘿,亲爱的手机用户们,你们有没有经历过那种电量只剩1%,却还有一堆事情没做完的绝望感?别担心,我今天...
出生证明大小-出生证明虽小却重... 哎呀,说到这出生证明啊,我这心里就五味杂陈的。别看它就那么一小张纸,薄薄的,轻飘飘的,可它上面印着的...
xp安装windows7-从 ... 哎呀,说到从XP升级到Windows7,我这心里啊,真是五味杂陈!XP老兄,你陪伴了我这么多年,虽然...
帝国cms 下载站模板-帝国 ... 哎呀,说到这个帝国CMS下载站模板,我简直激动得要跳起来!你们知道吗,这东西就像是一把魔法钥匙,能瞬...
pear os安装-PearO... 哎呀,说到这个PearOS啊,我可是有一肚子的话要说!你知道吗,当我第一次听说这个系统的时候,我简直...
帝国cms视频网站模板-帝国 ... 嘿,大家好!今天我要带你们走进一个充满魔力的世界——帝国CMS视频网站模板的世界!想象一下,你手握魔...
互联网舆情监控系统 项目建议书... 哎呀,说到这个互联网舆情监控系统,我简直要激动得跳起来了!这可不是一般的玩意儿,这是我们的眼睛,我们...
末日黎明安卓破解版:让更多人体... 大家好,我是你们的老朋友,一个游戏世界的狂热爱好者。今天,我要和大家聊聊那个让无数玩家疯狂的话题——...
汽车用电设备-爱车变身魔法盒子... 想象一下,你的爱车不仅仅是一台冷冰冰的机器,而是一个充满魔法的盒子,里面装满了各种神奇的电力小玩意儿...
fedora 25 iso下载... 嘿,大家好!今天咱们聊聊Fedora25的ISO下载,这可是一个让人激动的话题啊!想象一下,一个全新...
finaldata破解版 x0... 哎呀,朋友们,今天咱们得聊聊这个FinalData破解版的事儿。你们可能觉得这玩意儿能省下不少钱,还...
ecshop套模板教程-ECS... 嘿,各位网站小主们!是不是觉得自己的ECShop店铺有点儿单调,想换个新面孔,却又觉得技术门槛高得像...