试卷征集
加入会员
操作视频

【加试题】曲哲同学设计了一个英文字符串的加密算法,其加密的方法如下:
(1)从被加密字符串中获取单个字符,然后得到其ascii码的8位二进制编码.
(2)将字符的二进制编码反向,得到其逆序二进制码.
(3)将逆序二进制码的每4位转换为相应的十六进制编码,即得到单个字符加密后的字符串.
(4)以此类推,直到所有字符加密完成,得到加密字符串.
具体程序界面如图,在text1中输入字符串,点击“加密”按钮command1后,在text2中显示加密后的字符串.
(1)已知字符a的ascii码为97,则字符串idear加密后的字符串为
9626A6864E
9626A6864E

(2)阅读整段程序,程序中①横线处应填入
D2B(Mid(s,i,1))
D2B(Mid(s,i,1))
程序中②横线处应填入
m=m*2+Val(Mid(ch,i,1))
m=m*2+Val(Mid(ch,i,1))

Private Sub Command1_Click
(  )
(  )

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'获取二进制码前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位二进制编码
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))
【解答】
【点评】
声明:本试题解析著作权属菁优网所有,未经书面同意,不得复制发布。
发布:2024/6/27 10:35:59组卷:8引用:1难度:0.1
相似题
  • 1.运行列表框对象语句:List1.AddItem=“同学们好!“,会显示:同学们好!;
     
    (判断对错)

    发布:2025/1/2 11:30:1组卷:6引用:6难度:0.9
  • 2.小张设计了一个“加减运算练习”VB程序.界面如下图所示.单击“出题”Command1按钮显示两个运算数和运算符号,并计数.在文本框Text1中输入计算结果后单击“判断”按钮Command2,如果计算结果正确,则得分加10分,直至完成10题测试.VB程序如下,但加下横线处代码有错,请改正.
    Dim n,s As Integer'n为试题计数器,s为得分
    Dim a,b As Integer'a,b 为两个运算数
    Dim c As String'c为运算符:“+“表示加法,“-“表示减法
    Private Sub Form_Load(  )n=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为运算数,且要求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.

    发布:2025/1/2 9:30:2组卷:6引用:2难度:0.9
  • 3.某智能农场启用了根据土壤湿度自动控制喷淋装置进行浇水的信息系统,每隔一段时间,系统自动检测土壤湿度,当土壤湿度低于某个阈值时将自动浇水。小李为统计出某段时间内(不超过100个时间单位)系统自动控制浇水的次数和该时间段内前后两次启动自动浇水系统的最大时间间隔单位,小李进行了数据分析,他认为如果某单位时间的土壤湿度比前一单位时间的土壤湿度高并且本单位时间内没有下雨,则认为启用了浇水系统。由此他编写了一个VB程序实现该功能:在文本框Text1中输入某段时间内的湿度值,在文本框Text2中输入该段时间内对应的天气情况,单击命令按钮Command1,在文本框Text3中显示系统自动浇水次数,Text4中显示前后两次自动浇水系统启用的最大时间间隔单位。

    (1)在Private Sub Command1_Click(  )中,Command1、Click分别表示
     
    (单选,填字母:A.对象名、属性名/B.对象名、事件名/C.类名、方法名)。
    (2)实现上述功能的VB程序如下,请在画线处填入合适的代码。
    (3)程序中加框处代码有错,请改正。

    发布:2025/1/2 11:0:1组卷:0引用:1难度:0.3
深圳市菁优智慧教育股份有限公司
粤ICP备10006842号公网安备44030502001846号
©2010-2025 jyeoo.com 版权所有
APP开发者:深圳市菁优智慧教育股份有限公司| 应用名称:菁优网 | 应用版本:5.0.7 |隐私协议|第三方SDK|用户服务条款
广播电视节目制作经营许可证|出版物经营许可证|网站地图
本网部分资源来源于会员上传,除本网组织的资源外,版权归原作者所有,如有侵犯版权,请立刻和本网联系并提供证据,本网将在三个工作日内改正