阿摩線上測驗 登入

申論題資訊

試卷:104年 - 104年高等三級暨普通考普通_資訊處理#28869
科目:程式設計
年份:104年
排序:0

題組內容

二、如下程式,使用堆疊(Stack)的概念來存放數字基底轉換的結果,轉換完成後,再 將 Stack 內的資料一一取出,作結果的顯示;請依程式中標號的說明,於程式中填 入適當的程式碼,以完成十進位數字轉換為二、四、八、十六等四種進位制的數值。 (每小題 3 分,共 15 分)void base10toBaseNum(int sourceNum, int targetBase)
{ String ss = "";
if (sourceNum < 0)
{ ss = ("轉換基底的數字必須大於等於零"); }
else if ((targetBase == 2) || (targetBase == 4) ||
(targetBase == 8) || (targetBase == 16))
{ char [] base16 = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'};
ArrayList result = /* ⑴ 創造 ArrayList 物件 */;
for (int rr = /* ⑵ 設定迴圈起始狀態 */; rr > 0;
rr = /* ⑶ 改變控制變數 */)
{ result.add(/* ⑷ 加入餘數 0~F 的字元到 ArrayList */); }
ss = ("轉換" + sourceNum + "到基底" + targetBase + ": ");
for(int i = /* ⑸ 由後往前取出 ArrayList 內容資料 */; i--)
{ ss += ("" + result.get(i));
if ((i%4) == 0) { ss += (" "); }
}
ss += "
";
}
else { ss = ("轉換至的基底只能是 2, 4, 8, 16"); }
/* print out ss */
} // End of base10toBaseNum

申論題內容

⑷加入餘數 0~F 的字元到 ArrayList

詳解 (共 3 筆)

詳解 提供者:kmlu1111
base16[rr%targetBase]
詳解 提供者:moerstw
base16 (16 - rr)
詳解 提供者:hchungw
當進行數字基底轉換時,每次迭代計算得到的餘數對應於基底轉換後的一個數字或字母(對於十六進位來說)。我們可以通過對輸入數字 sourceNum 進行模 targetBase 操作來獲取這個餘數,然後使用之前定義的 base16 字符陣列來找到對應的字符(因為即使是轉換到二進位、四進位或八進位,0-F 中的前幾個字符依然是適用的)。
所以,加入餘數 0~F 的字元到 ArrayList 的程式碼如下:

result.add(base16[rr % targetBase]);
這行程式碼做了兩件事:
通過 rr % targetBase 計算出當前 rr 除以 targetBase 的餘數。
使用這個餘數作為索引從 base16 字符陣列中選取對應的字符,並將這個字符加入到 result 這個 ArrayList 中。