【加試題】曲哲同學(xué)設(shè)計了一個英文字符串的加密算法,其加密的方法如下:
(1)從被加密字符串中獲取單個字符,然后得到其ascii碼的8位二進(jìn)制編碼.
(2)將字符的二進(jìn)制編碼反向,得到其逆序二進(jìn)制碼.
(3)將逆序二進(jìn)制碼的每4位轉(zhuǎn)換為相應(yīng)的十六進(jìn)制編碼,即得到單個字符加密后的字符串.
(4)以此類推,直到所有字符加密完成,得到加密字符串.
具體程序界面如圖,在text1中輸入字符串,點(diǎn)擊“加密”按鈕command1后,在text2中顯示加密后的字符串.
(1)已知字符a的ascii碼為97,則字符串idear加密后的字符串為 9626A6864E9626A6864E.
(2)閱讀整段程序,程序中①橫線處應(yīng)填入 D2B(Mid(s,i,1))D2B(Mid(s,i,1))程序中②橫線處應(yīng)填入 m=m*2+Val(Mid(ch,i,1))m=m*2+Val(Mid(ch,i,1)).
Private Sub Command1_Click ( ?。?/div>( ?。?/div>
Dim s As String,ch As String
Dim result As String,chA As String,chB As String ‘’‘’
Dim i As Integer,j As Integer
Dim n As Integer,m As Integer
s=Text1.Text
n=Len(s)
result=““:c=“0123456789ABCDEF“
For i=1To n
ch=①D2B(Mid(s,i,1))D2B(Mid(s,i,1))
ch=niXu(ch)
m=0
For j=1To 4'獲取二進(jìn)制碼前4位的值②m=m*2+Val(Mid(ch,i,1))m=m*2+Val(Mid(ch,i,1))
Next
chA=Mid(c,m+1,1)
m=0
For j=5To Len(ch)
m=m*2+Val(Mid(ch,j,1))
Next
chB=Mid(c,m+1,1)
result=result+chA+chB
Next
Text2.Text=result
End Sub
'得到單個字符ch的8位二進(jìn)制編碼
Function D2B(ByVal ch As String) As String
Dim s As String
Dim data As Integer,i As Integer
data=Asc(ch):s=““
Do While data>0
s=Str(data Mod 2)+s
data=data\2
Loop
If Len(s)<8Then
For i=1To 8-Len(s)
s=“0“+s
Next
D2B=s
Else
D2B=s
End If
End Function
'返回字符串s的逆序
Function niXu(ByVal s As String) As String
Dim i As Integer:Dim r As String
r=““
For i=Len(s) To 1Step-1
r=r+Mid(s,i,1)
Next
niXu=r
End Function.【答案】9626A6864E;D2B(Mid(s,i,1));m=m*2+Val(Mid(ch,i,1));( );‘’;D2B(Mid(s,i,1));m=m*2+Val(Mid(ch,i,1))【解答】【點(diǎn)評】聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。發(fā)布:2024/6/27 10:35:59組卷:8引用:1難度:0.1
相似題
-
1.運(yùn)行列表框?qū)ο笳Z句:List1.AddItem=“同學(xué)們好!“,會顯示:同學(xué)們好!; (判斷對錯)
發(fā)布:2025/1/2 11:30:1組卷:6引用:6難度:0.9
-
2.某智能農(nóng)場啟用了根據(jù)土壤濕度自動控制噴淋裝置進(jìn)行澆水的信息系統(tǒng),每隔一段時間,系統(tǒng)自動檢測土壤濕度,當(dāng)土壤濕度低于某個閾值時將自動澆水。小李為統(tǒng)計出某段時間內(nèi)(不超過100個時間單位)系統(tǒng)自動控制澆水的次數(shù)和該時間段內(nèi)前后兩次啟動自動澆水系統(tǒng)的最大時間間隔單位,小李進(jìn)行了數(shù)據(jù)分析,他認(rèn)為如果某單位時間的土壤濕度比前一單位時間的土壤濕度高并且本單位時間內(nèi)沒有下雨,則認(rèn)為啟用了澆水系統(tǒng)。由此他編寫了一個VB程序?qū)崿F(xiàn)該功能:在文本框Text1中輸入某段時間內(nèi)的濕度值,在文本框Text2中輸入該段時間內(nèi)對應(yīng)的天氣情況,單擊命令按鈕Command1,在文本框Text3中顯示系統(tǒng)自動澆水次數(shù),Text4中顯示前后兩次自動澆水系統(tǒng)啟用的最大時間間隔單位。
(1)在Private Sub Command1_Click( ?。┲?,Command1、Click分別表示 (單選,填字母:A.對象名、屬性名/B.對象名、事件名/C.類名、方法名)。
(2)實(shí)現(xiàn)上述功能的VB程序如下,請在畫線處填入合適的代碼。
(3)程序中加框處代碼有錯,請改正。
發(fā)布:2025/1/2 11:0:1組卷:0引用:1難度:0.3
-
3.小張設(shè)計了一個“加減運(yùn)算練習(xí)”VB程序.界面如下圖所示.單擊“出題”Command1按鈕顯示兩個運(yùn)算數(shù)和運(yùn)算符號,并計數(shù).在文本框Text1中輸入計算結(jié)果后單擊“判斷”按鈕Command2,如果計算結(jié)果正確,則得分加10分,直至完成10題測試.VB程序如下,但加下橫線處代碼有錯,請改正.
Dim n,s As Integer'n為試題計數(shù)器,s為得分
Dim a,b As Integer'a,b 為兩個運(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=“完成測試“
End If
End Sub
Private Sub Command2_Click( )‘判斷按鈕
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
( ?。?/div>
Dim s As String,ch As String
Dim result As String,chA As String,chB As String
Dim i As Integer,j As Integer
Dim n As Integer,m As Integer
s=Text1.Text
n=Len(s)
result=““:c=“0123456789ABCDEF“
For i=1To n
ch=①
ch=niXu(ch)
m=0
For j=1To 4'獲取二進(jìn)制碼前4位的值②
Next
chA=Mid(c,m+1,1)
m=0
For j=5To Len(ch)
m=m*2+Val(Mid(ch,j,1))
Next
chB=Mid(c,m+1,1)
result=result+chA+chB
Next
Text2.Text=result
End Sub
'得到單個字符ch的8位二進(jìn)制編碼
Function D2B(ByVal ch As String) As String
Dim s As String
Dim data As Integer,i As Integer
data=Asc(ch):s=““
Do While data>0
s=Str(data Mod 2)+s
data=data\2
Loop
If Len(s)<8Then
For i=1To 8-Len(s)
s=“0“+s
Next
D2B=s
Else
D2B=s
End If
End Function
'返回字符串s的逆序
Function niXu(ByVal s As String) As String
Dim i As Integer:Dim r As String
r=““
For i=Len(s) To 1Step-1
r=r+Mid(s,i,1)
Next
niXu=r
End Function.
Dim s As String,ch As String
Dim result As String,chA As String,chB As String
‘’
‘’
Dim i As Integer,j As Integer
Dim n As Integer,m As Integer
s=Text1.Text
n=Len(s)
result=““:c=“0123456789ABCDEF“
For i=1To n
ch=①
D2B(Mid(s,i,1))
D2B(Mid(s,i,1))
ch=niXu(ch)
m=0
For j=1To 4'獲取二進(jìn)制碼前4位的值②
m=m*2+Val(Mid(ch,i,1))
m=m*2+Val(Mid(ch,i,1))
Next
chA=Mid(c,m+1,1)
m=0
For j=5To Len(ch)
m=m*2+Val(Mid(ch,j,1))
Next
chB=Mid(c,m+1,1)
result=result+chA+chB
Next
Text2.Text=result
End Sub
'得到單個字符ch的8位二進(jìn)制編碼
Function D2B(ByVal ch As String) As String
Dim s As String
Dim data As Integer,i As Integer
data=Asc(ch):s=““
Do While data>0
s=Str(data Mod 2)+s
data=data\2
Loop
If Len(s)<8Then
For i=1To 8-Len(s)
s=“0“+s
Next
D2B=s
Else
D2B=s
End If
End Function
'返回字符串s的逆序
Function niXu(ByVal s As String) As String
Dim i As Integer:Dim r As String
r=““
For i=Len(s) To 1Step-1
r=r+Mid(s,i,1)
Next
niXu=r
End Function.
【答案】9626A6864E;D2B(Mid(s,i,1));m=m*2+Val(Mid(ch,i,1));( );‘’;D2B(Mid(s,i,1));m=m*2+Val(Mid(ch,i,1))
【解答】
【點(diǎn)評】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/6/27 10:35:59組卷:8引用:1難度:0.1
相似題
-
1.運(yùn)行列表框?qū)ο笳Z句:List1.AddItem=“同學(xué)們好!“,會顯示:同學(xué)們好!;
發(fā)布:2025/1/2 11:30:1組卷:6引用:6難度:0.9 -
2.某智能農(nóng)場啟用了根據(jù)土壤濕度自動控制噴淋裝置進(jìn)行澆水的信息系統(tǒng),每隔一段時間,系統(tǒng)自動檢測土壤濕度,當(dāng)土壤濕度低于某個閾值時將自動澆水。小李為統(tǒng)計出某段時間內(nèi)(不超過100個時間單位)系統(tǒng)自動控制澆水的次數(shù)和該時間段內(nèi)前后兩次啟動自動澆水系統(tǒng)的最大時間間隔單位,小李進(jìn)行了數(shù)據(jù)分析,他認(rèn)為如果某單位時間的土壤濕度比前一單位時間的土壤濕度高并且本單位時間內(nèi)沒有下雨,則認(rèn)為啟用了澆水系統(tǒng)。由此他編寫了一個VB程序?qū)崿F(xiàn)該功能:在文本框Text1中輸入某段時間內(nèi)的濕度值,在文本框Text2中輸入該段時間內(nèi)對應(yīng)的天氣情況,單擊命令按鈕Command1,在文本框Text3中顯示系統(tǒng)自動澆水次數(shù),Text4中顯示前后兩次自動澆水系統(tǒng)啟用的最大時間間隔單位。
(1)在Private Sub Command1_Click( ?。┲?,Command1、Click分別表示
(2)實(shí)現(xiàn)上述功能的VB程序如下,請在畫線處填入合適的代碼。
(3)程序中加框處代碼有錯,請改正。發(fā)布:2025/1/2 11:0:1組卷:0引用:1難度:0.3 -
3.小張設(shè)計了一個“加減運(yùn)算練習(xí)”VB程序.界面如下圖所示.單擊“出題”Command1按鈕顯示兩個運(yùn)算數(shù)和運(yùn)算符號,并計數(shù).在文本框Text1中輸入計算結(jié)果后單擊“判斷”按鈕Command2,如果計算結(jié)果正確,則得分加10分,直至完成10題測試.VB程序如下,但加下橫線處代碼有錯,請改正.
Dim n,s As Integer'n為試題計數(shù)器,s為得分
Dim a,b As Integer'a,b 為兩個運(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=“完成測試“
End If
End Sub
Private Sub Command2_Click( )‘判斷按鈕
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
把好題分享給你的好友吧~~
APP開發(fā)者:深圳市菁優(yōu)智慧教育股份有限公司| 應(yīng)用名稱:菁優(yōu)網(wǎng) | 應(yīng)用版本:5.0.7 |隱私協(xié)議|第三方SDK|用戶服務(wù)條款
本網(wǎng)部分資源來源于會員上傳,除本網(wǎng)組織的資源外,版權(quán)歸原作者所有,如有侵犯版權(quán),請立刻和本網(wǎng)聯(lián)系并提供證據(jù),本網(wǎng)將在三個工作日內(nèi)改正