有一種ASCII字符加密的算法,其加密過程如下:
①將明碼中每個(gè)字符的八位二進(jìn)制ASCII碼(不足八位的左端補(bǔ)0,湊足八位)分成兩段(左4位高位段,右4位低位段)。如字符“C”的二進(jìn)制ASCII碼為01000011,分段后為0100,0011。
②將高位段(左邊4位)左移一位,并將原第一位數(shù)碼移至最后(如0100轉(zhuǎn)化為1000),再轉(zhuǎn)化為十六進(jìn)制數(shù)(如1000轉(zhuǎn)化為8)。
③對(duì)低位段(右邊4位)執(zhí)行②同樣的算法,如0011→0110→6。
④順次連接兩位十六進(jìn)制數(shù),得到該字符的密文,如“C”的密文為“86”。
⑤將每個(gè)字符的密文按明碼的順序連接。
用python編寫的程序運(yùn)行結(jié)果如圖所示,請(qǐng)回答下列問題:
答題提示:
本題(2)(3)兩小題的計(jì)算表達(dá)式可能會(huì)涉及到以下運(yùn)算符(它們優(yōu)先級(jí)相同):
乘:*實(shí)數(shù)除法:/整除://求余數(shù):%
具體使用方法如下:
5*2=10,5/2=2.5,5//2=2,5%2=1
(1)按照加密算法,明碼字符“J”的密文是
85
85
;密文“C2”的明碼是
a
a
。
(2)假設(shè)某字符ASCII值的十進(jìn)制數(shù)為m,則該數(shù)的高位段是
m//16
m//16
,低位段是
m%16
m%16
(結(jié)果都是十進(jìn)制)。
(3)假設(shè)(2)中高位段的四位二進(jìn)制轉(zhuǎn)十進(jìn)制為n,則經(jīng)過加密算法第②步運(yùn)算:左移一位,將原第一位移至最后,得到的值是
n%8*2+n//8(或其他等價(jià)表達(dá)式)
n%8*2+n//8(或其他等價(jià)表達(dá)式)
(結(jié)果為十進(jìn)制)。