PS:本身寫的,自測試OK,供你們參考。java
/*數組
高級題樣題:地鐵換乘
描述:已知2條地鐵線路,其中A爲環線,B爲東西向線路,線路都是雙向的。通過的站點名分別以下,兩條線交叉的換乘點用T一、T2表示。
編寫程序,任意輸入兩個站點名稱,輸出乘坐地鐵最少須要通過的車站數量(含輸入的起點和終點,換乘站點只計算一次)。
地鐵線A(環線)通過車站:A1 A2 A3 A4 A5 A6 A7 A8 A9 T1 A10 A11 A12 A13 T2 A14 A15 A16 A17 A18
地鐵線B(直線)通過車站:B1 B2 B3 B4 B5 T1 B6 B7 B8 B9 B10 T2 B11 B12 B13 B14 B15
輸入:輸入兩個不一樣的站名
輸出:輸出最少通過的站數,含輸入的起點和終點,換乘站點只計算一次
輸入樣例:A1 A3
輸出樣例:3測試
(注意:按照題示,A1 A3結果爲3,因此A1 A1結果就應該爲1,依此。)
*/spa
1 import java.util.Scanner; 2 3 public class Station { 4 5 static String strA = "A1 A2 A3 A4 A5 A6 A7 A8 A9 T1 A10 A11 A12 A13 T2 A14 A15 A16 A17 A18"; 6 static String strB = "B1 B2 B3 B4 B5 T1 B6 B7 B8 B9 B10 T2 B11 B12 B13 B14 B15"; 7 8 static String[] SA = strA.split(" "); 9 static String[] SB = strB.split(" "); 10 11 static int LENSA = SA.length; 12 static int LENSB = SB.length; 13 14 static int indexT1SA = getIndexofSA("T1"); //"T1"車站在A線路上的數組下標 15 static int indexT1SB = getIndexofSB("T1"); //"T1"車站在B線路上的數組下標 16 static int indexT2SA = getIndexofSA("T2"); //"T2"車站在A線路上的數組下標 17 static int indexT2SB = getIndexofSB("T2"); //"T2"車站在B線路上的數組下標 18 19 public static void main(String[] args) { 20 21 int step = 0; 22 System.out.println("請輸入\"始發站\"(空格)\"終到站\"(例如:A1 B4(回車結束)):"); 23 Scanner sc = new Scanner(System.in); 24 String[] strArray = sc.nextLine().split(" "); 25 26 String x = strArray[0].toUpperCase(); 27 String y = strArray[1].toUpperCase(); 28 29 System.out.println("go:"+x); 30 System.out.println("to:"+y); 31 32 sc.close(); 33 34 step = getMinStep(x, y) + 1; 35 System.out.println("通過的最少車站數:"+step); 36 } 37 38 private static int getMinStep(String x, String y) { 39 40 if(('A' != x.charAt(0))&&('A' != y.charAt(0))) 41 { 42 //在地鐵B線路上 43 return min(stepBtoB(x, y), stepT1orT2(x, y)); 44 } 45 else if(('B' != x.charAt(0))&&('B' != y.charAt(0))) 46 { 47 //在地鐵A線路上 48 return min(stepAtoA(x, y), stepT1orT2(x, y)); 49 } 50 else 51 { 52 //A到B,或者B到A 53 return stepT1orT2(x, y); 54 } 55 } 56 57 //從T1或者T2站換乘,s1到s2的最短距離 58 private static int stepT1orT2(String s1, String s2) { 59 int lenXtoT1 = steptoT1(s1); 60 int lenXtoT2 = steptoT2(s1); 61 int lenYtoT1 = steptoT1(s2); 62 int lenYtoT2 = steptoT2(s2); 63 64 int lineT1 = lenXtoT1 + lenYtoT1; 65 int lineT2 = lenXtoT2 + lenYtoT2; 66 67 return min(lineT1, lineT2); 68 } 69 70 //到T1的最短距離 71 private static int steptoT1(String s) { 72 73 if("T1".equals(s)) 74 { 75 return 0; 76 } 77 else if("T2".equals(s)) 78 { 79 return min(stepAtoA("T1", "T2"), stepBtoB("T1", "T2")); 80 } 81 else if('A' == s.charAt(0)) //s是A線路上的車站 82 { 83 //找到s站在SA的下標 84 int indexSSA = getIndexofSA(s); 85 86 //不換乘,s到T1最短路程 87 int line1 = min(mod(indexSSA, indexT1SA), LENSA-mod(indexSSA, indexT1SA)); 88 //不換乘,s到T2最短路程 89 int line2 = min(mod(indexSSA, indexT2SA), LENSA-mod(indexSSA, indexT2SA)); 90 91 return min(line1, line2+min(stepAtoA("T1", "T2"), stepBtoB("T1", "T2"))); 92 } 93 else if('B' == s.charAt(0)) //s是B線路上的車站 94 { 95 //找到s站在SB的下標 96 int indexSSB = getIndexofSB(s); 97 98 //不換乘,s到T1最短路程 99 int line1 = mod(indexSSB, indexT1SB); 100 //不換乘,s到T2最短路程 101 int line2 = mod(indexSSB, indexT2SB); 102 103 return min(line1, line2+min(stepAtoA("T1", "T2"), stepBtoB("T1", "T2"))); 104 } 105 else 106 { 107 System.out.println("車站名有誤,請檢查!"); 108 return -1; 109 } 110 } 111 112 //s到T2的最短距離 113 private static int steptoT2(String s) { 114 115 if("T2".equals(s)) 116 { 117 return 0; 118 } 119 else if("T1".equals(s)) 120 { 121 return min(stepAtoA("T1", "T2"), stepBtoB("T1", "T2")); 122 } 123 else if('A' == s.charAt(0)) //s是A線路上的車站 124 { 125 //找到s站在SA的下標 126 int indexSSA = getIndexofSA(s); 127 128 //不換乘,s到T1最短路程 129 int line1 = min(mod(indexSSA, indexT1SA), LENSA-mod(indexSSA, indexT1SA)); 130 //不換乘,s到T2最短路程 131 int line2 = min(mod(indexSSA, indexT2SA), LENSA-mod(indexSSA, indexT2SA)); 132 133 return min(line2, line1+min(stepAtoA("T1", "T2"), stepBtoB("T1", "T2"))); 134 } 135 else if('B' == s.charAt(0)) //s是B線路上的車站 136 { 137 //找到s站在SB的下標 138 int indexSSB = getIndexofSB(s); 139 140 //不換乘,s到T1最短路程 141 int line1 = mod(indexSSB, indexT1SB); 142 //不換乘,s到T2最短路程 143 int line2 = mod(indexSSB, indexT2SB); 144 145 return min(line2, line1+min(stepAtoA("T1", "T2"), stepBtoB("T1", "T2"))); 146 } 147 else 148 { 149 System.out.println("車站名有誤,請檢查!"); 150 return -1; 151 } 152 } 153 154 //A到A,不換乘 155 private static int stepAtoA(String s1, String s2) { 156 if(('B' == s1.charAt(0))||('B' == s2.charAt(0))) 157 { 158 System.out.println("輸入不是A線路上的站點,請檢查!"); 159 return -1; 160 } 161 162 //找到s1站,在A線路上的數組下標 163 int indexS1SA = getIndexofSA(s1); 164 165 //找到s2站,在A線路上的數組下標 166 int indexS2SA = getIndexofSA(s2); 167 168 //不換乘,s1到s2的最短距離 169 return min(mod(indexS1SA, indexS2SA), LENSA-mod(indexS1SA, indexS2SA)); 170 } 171 172 //B到B,不換乘 173 private static int stepBtoB(String s1, String s2) { 174 if(('A' == s1.charAt(0))||('A' == s2.charAt(0))) 175 { 176 System.out.println("輸入不是B線路上的站點,請檢查!"); 177 return -1; 178 } 179 180 //找到s1站,在B線路上的數組下標 181 int indexS1SB = getIndexofSB(s1); 182 183 //找到s2站,在B線路上的數組下標 184 int indexS2SB = getIndexofSB(s2); 185 186 //不換乘,s1到s2的最短距離 187 return mod(indexS1SB, indexS2SB); 188 } 189 190 private static int min(int a, int b) 191 { 192 return a<b?a:b; 193 } 194 195 private static int getIndexofSA(String str) 196 { 197 for(int index = 0; index < LENSA; index++) 198 { 199 if(str.equals(SA[index])) 200 { 201 return index; 202 } 203 } 204 205 return -1; 206 } 207 208 private static int getIndexofSB(String str) 209 { 210 for(int index = 0; index < LENSB; index++) 211 { 212 if(str.equals(SB[index])) 213 { 214 return index; 215 } 216 } 217 218 return -1; 219 } 220 221 private static int mod(int a, int b) 222 { 223 if(a < b) 224 { 225 return b-a; 226 } 227 else 228 { 229 return a-b; 230 } 231 } 232 }