- 1、本文档共26页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数字和符处理题型分析
※数字和字符处理题型分析
(2)执行下面的程序,单击窗体后在窗体上显示的第一行结果是 [1] ,第三行结果是__[2]__。
Private Sub Command1_Click()
Dim Mystr, MyStr1, Mystr2 As String
MyStr1 = B
For i = 1 To 3
Mystr2 = LCase(MyStr1)
MyStr1 = MyStr1 Mystr2
Mystr = Mystr MyStr1
Print Mystr
MyStr1 = Chr(Asc(MyStr1)+ i)
Next i
End Sub
i
MyStr1
MyStr2
MyStr
打印
B
1
Bb
b
Bb
Bb
C
2
Cc
c
E
BbCc
BbCc
3
Ee
e
BbCcEe
BbCcEe
答案:(1)Bb
(2)BbCcEe
分析:Asc()函数只取第一个字符的数值。
7.下面是一个加密/解密程序,加密的算法是:将原文中每个字符的ASCII代码加上该字符在原文中的位置数(设字符在原文中是第n个字符,在其位置是n被10除的余数,当余数为0时,其位置数为10。例如原文字符串为“meet me at sunset”,第一个字符“m”,其位置数为1,而“s”为第12个字符,其位置数是被10除的余数2,其余依次类推)作为密文字符的代码,再将密码字符逆序排列(例如ABCD,逆序排列为DCBA)即为密文。解密算法是加密算法的逆运算。
Option Explicit
Private Sub Command1_Click() 加密
Dim enc As String, dec As String, i As Integer
Dim s As String * 1, n As Integer
dec = Text1
For i = 1 To Len(dec)
s = Mid(dec, i, 1)
(19)
If n = 0 Then n = 10
enc = Chr(Asc(s) + n) enc
Next i
Text2 = enc
End Sub
Private Sub Command2_Click() 解密
Dim enc As String, dec As String, i As Integer
Dim n As Integer, s As String * 1, p As Integer
enc = Text2
(20)
For i = 1 To n
s = Mid(enc, i, 1)
p = n Mod 10
If p = 0 Then p = 10
dec = (21)
n = n - 1
Next i
Text1 = dec
End Sub
答案:n = i Mod 10 n = Len(enc) Chr(Asc(s) - p) dec
(4)运行下面的程序,单击窗体后在窗体上显示的第一行结果是 [1] ,第三行结果是 [2] 。
Private Sub Form_Click()
Dim mst As String, mst1 As String, mst2 As String
Dim i As Integer
mst1 = CeBbAa
For i = Len(mst1) To 1 Step -2
mst2 = Mid(mst1, i - 1, 2)
mst = mst mst2
Print mst
Next i
End Sub
mst1
mst2
mst
i
打印
CeBbAa
Aa
Aa
6
Aa
Bb
AaBb
4
AaBb
Cc
AaBbc
2
AaBbc
答案:(8)Aa
(9)AaBbCe
分析:Mid()函数的操作方式是从后向前取字符。
(2)执行下面程序,第二行输出结果是 [1] ,第三行输出结果是 [2] 。
Private Sub Form_Click()
Dim ch As String, i As Integer
ch = ABC
For i = 1 To 3
ch = Mid(ch, 2 * i - 1, 1)+ Left(ch, Len(ch))
Print ch
Next i
End Sub
ch
i
打印
ABC
1
Mid(ABC,1
文档评论(0)