【加試題】某數(shù)據(jù)加密方法描述如下:
(1)以字節(jié)為單位進(jìn)行加密處理;
(2)將1個(gè)字節(jié)的8位二進(jìn)制數(shù)分割成前4位與后4位兩個(gè)二進(jìn)制數(shù);
(3)分別將上述兩個(gè)4位二進(jìn)制數(shù)轉(zhuǎn)換為十進(jìn)制數(shù);
(4)將每個(gè)十進(jìn)制數(shù)轉(zhuǎn)換為1個(gè)加密字符,對(duì)應(yīng)的“密碼表”如下:
值(十進(jìn)制) | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
加密字符 | I | l | i | k | e | C | H | N | P | 0 | s | t | c | a | r | d |
![](http://img.jyeoo.net/quiz/images/201705/44/de13a966.png)
程序運(yùn)行效果如圖2所示.
實(shí)現(xiàn)上述功能的VB程序如下:
(1)請(qǐng)?zhí)钊牒线m代碼.
Private Sub Command1_Click ( )
Dim n As Integer,s As String,i As Integer,ss As String
Dim a As Integer'存儲(chǔ)加密前字符的ASCII碼
Dim b1As Integer,b2As Integer'分別存儲(chǔ)分割、轉(zhuǎn)換后的兩個(gè)十進(jìn)制數(shù)
s=Text1.Text
①
n=Len(s)
n=Len(s)
For i=1To n
a=Asc(Mid(s,i,1))
b1=a\16
b2=a Mod 16
ss=ss+Code2Char(b1)+Code2Char(b2)
Text2.Text=ss
Next i
End Sub
'十進(jìn)制值轉(zhuǎn)換為加密字符的函數(shù)
Function Code2Char(c As Integer) As String
Dim s As String
s=“IlikeCHNpostcard”
Code2Char=②
Mid(s,c+1,1)
Mid(s,c+1,1)
End Function
(2)若將“密碼表”中值為“0”對(duì)應(yīng)的加密字符“I”改成“i”,加密后的密文可能無(wú)法解密,原因是
加密字符i對(duì)應(yīng)兩個(gè)值0,2
加密字符i對(duì)應(yīng)兩個(gè)值0,2
.【答案】n=Len(s);Mid(s,c+1,1);加密字符i對(duì)應(yīng)兩個(gè)值0,2
【解答】
【點(diǎn)評(píng)】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/4/20 14:35:0組卷:14引用:5難度:0.1
相似題
-
1.運(yùn)行列表框?qū)ο笳Z(yǔ)句:List1.AddItem=“同學(xué)們好!“,會(huì)顯示:同學(xué)們好!;
發(fā)布:2025/1/2 11:30:1組卷:6引用:6難度:0.9 -
2.某智能農(nóng)場(chǎng)啟用了根據(jù)土壤濕度自動(dòng)控制噴淋裝置進(jìn)行澆水的信息系統(tǒng),每隔一段時(shí)間,系統(tǒng)自動(dòng)檢測(cè)土壤濕度,當(dāng)土壤濕度低于某個(gè)閾值時(shí)將自動(dòng)澆水。小李為統(tǒng)計(jì)出某段時(shí)間內(nèi)(不超過(guò)100個(gè)時(shí)間單位)系統(tǒng)自動(dòng)控制澆水的次數(shù)和該時(shí)間段內(nèi)前后兩次啟動(dòng)自動(dòng)澆水系統(tǒng)的最大時(shí)間間隔單位,小李進(jìn)行了數(shù)據(jù)分析,他認(rèn)為如果某單位時(shí)間的土壤濕度比前一單位時(shí)間的土壤濕度高并且本單位時(shí)間內(nèi)沒(méi)有下雨,則認(rèn)為啟用了澆水系統(tǒng)。由此他編寫了一個(gè)VB程序?qū)崿F(xiàn)該功能:在文本框Text1中輸入某段時(shí)間內(nèi)的濕度值,在文本框Text2中輸入該段時(shí)間內(nèi)對(duì)應(yīng)的天氣情況,單擊命令按鈕Command1,在文本框Text3中顯示系統(tǒng)自動(dòng)澆水次數(shù),Text4中顯示前后兩次自動(dòng)澆水系統(tǒng)啟用的最大時(shí)間間隔單位。
(1)在Private Sub Command1_Click( ?。┲?,Command1、Click分別表示
(2)實(shí)現(xiàn)上述功能的VB程序如下,請(qǐng)?jiān)诋嬀€處填入合適的代碼。
(3)程序中加框處代碼有錯(cuò),請(qǐng)改正。發(fā)布:2025/1/2 11:0:1組卷:0引用:1難度:0.3 -
3.小張?jiān)O(shè)計(jì)了一個(gè)“加減運(yùn)算練習(xí)”VB程序.界面如下圖所示.單擊“出題”Command1按鈕顯示兩個(gè)運(yùn)算數(shù)和運(yùn)算符號(hào),并計(jì)數(shù).在文本框Text1中輸入計(jì)算結(jié)果后單擊“判斷”按鈕Command2,如果計(jì)算結(jié)果正確,則得分加10分,直至完成10題測(cè)試.VB程序如下,但加下橫線處代碼有錯(cuò),請(qǐng)改正.
Dim n,s As Integer'n為試題計(jì)數(shù)器,s為得分
Dim a,b As Integer'a,b 為兩個(gè)運(yùn)算數(shù)
Dim c As String'c為運(yùn)算符:“+“表示加法,“-“表示減法
Private Sub Form_Load( ?。﹏=0:
s=0
End Sub
Private Sub Command1_Click( )‘出題按鈕
Randomize
n=n+1
If n<11Then
Label1.Caption=“No:“+Str(n)
a=Int(Rnd*100)'a,b為運(yùn)算數(shù),且要求a不小于b
b=Int(Rnd*100)
If a>bThen t=a:a=b:b=t'(1)
If Rnd>0.5Then c=“+“Else b=“-“'(2)
Label5.Caption=Str(a)+c+Str(b)+“=“
Text1.Text=““
Else
Command1.Caption=“完成測(cè)試“
End If
End Sub
Private Sub Command2_Click( ?。袛喟粹o
If c=“+“Then
If a+b=Val(Text1.Text) Then s=s+10
Else
If a+b=Val(Text1.Text)Then s=s+10'(3)
End If
Label3.Caption=“得分:“+Str(s)
End Sub.發(fā)布:2025/1/2 9:30:2組卷:6引用:2難度:0.9