華爲上機測試題(地鐵換乘-java)

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 }
相關文章
相關標籤/搜索