PTA乙级1048
1048
本題要求實現一種數字加密方法。首先固定一個加密用正整數 A,對任一正整數 B,將其每 1 位數字與 A 的對應位置上的數字進行以下運算:對奇數位,對應位的數字相加后對 13 取余——這里用 J 代表 10、Q 代表 11、K 代表 12;對偶數位,用 B 的數字減去 A 的數字,若結果為負數,則再加 10。這里令個位為第 1 位。
輸入格式:
輸入在一行中依次給出 A 和 B,均為不超過 100 位的正整數,其間以空格分隔。
輸出格式:
在一行中輸出加密后的結果。
輸入樣例:
1234567 368782971
輸出樣例:
3695Q8118
思路:先用bufferreader獲取這一行字符串,然后用空格劃分為A和B,然后存入數組,通過對A的每一位判斷是偶數還是奇數
在進行詳細判斷,這里我用StringBuilder存儲每次獲得的數或者是JQK,最后反轉輸出。
代碼;
package test1;import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader;public class PTA1048 {public static void main(String[] args) throws IOException {BufferedReader br=new BufferedReader(new InputStreamReader(System.in));String k=br.readLine();String[] l= k.split("\\s+");String[] a=l[0].split("");String[] b=l[1].split("");int m=a.length-1;StringBuilder c=new StringBuilder();for(int i=(b.length-1);i>=0;i--) {if (m >= 0) {if (Integer.parseInt(a[m]) % 2 == 1) {//為奇數String d = String.valueOf((Integer.parseInt(b[i]) + Integer.parseInt(a[m])) % 13);if (Integer.parseInt(d) == 10) {c.append("J");}if (Integer.parseInt(d) == 11) {c.append("Q");}if (Integer.parseInt(d) == 12) {c.append("J");}if (Integer.parseInt(d) < 10 && Integer.parseInt(d) >= 0) {c.append(Integer.parseInt(d));}}if (Integer.parseInt(a[m]) % 2 == 0) {//為偶數int d = Integer.parseInt(b[i]) - Integer.parseInt(a[m]);if (d >= 0) {c.append(d);}if (d < 0) {d = d + 10;c.append(d);}}m--;}if(m<0){//B對應A位置沒數了直接跳出循環break;}}for(int i=b.length-a.length-1;i>=0;i--){c.append(b[i]);}System.out.println(c.reverse());} }總結
- 上一篇: Android 中Goolgle 相关服
- 下一篇: 第七章-填充符号表