您现在的位置: 中国男护士网 >> 考试频道 >> 计算机等级 >> 二级辅导 >> VB >> 辅导 >> 正文    
  VB常用算法(四)进制转化 【注册男护士专用博客】          

VB常用算法(四)进制转化

www.nanhushi.com     佚名   不详 

1、算法说明

1)        十进制正整数m转换为R216)进制的字符串。

         思路: m不断除r取余数,直到商为0,将余数反序即得到结果。

         算法实现:

Private Function Tran(ByVal m As Integer, ByVal r As Integer) As String

    Dim StrDtoR As String, n As Integer

    Do While m <> o

        n = m Mod r

        m = m \ r

        If n > 9 Then

            StrDtoR = Chr(65 + n - 10) & StrDtoR

        Else

            StrDtoR = n & StrDtoR

        End If

    Loop

    Tran = StrDtoR

End Function

 

2)        R216)进制字符串转换为十进制正整数。

         思路:R进制数每位数字乘以权值之和即为十进制数。

         算法实现:

Private Function Tran(ByVal s As String, ByVal r As Integer) As integer

    Dim n As Integer, dec As Integer

    s = UCase(Trim(s))

    For i% = 1 To Len(s)

               If Mid(s, i, 1) >= "A" Then

                        n = Asc(Mid(s, i, 1)) - Asc("A") + 10

               Else

                        n = Val(Mid(s, i, 1))

               End If

               dec = dec + n * r ^ (Len(s) - i)

    Next i

    Tran = dec

End Function

 

解题技巧

         进制转化的原理要清楚,同时编写代码时候要留意16进制中的AF字符的处理。

 

2、实战练习

1)        补充代码(2002秋二(9))

         本程序是把给定的二进制整数转换为八进制整数。

                  Private Sub Command1_Click()

                           Dim a As String, b As String, c As String

                           Dim L As Integer, m As Integer, n As Integer

                           a = InputBox("请输入一个二进制数", "输入框")

                              1    

                           a = String(L, "0") & a

                              2    

                           For m = 1 To n / 3

                             b = Mid(a, 3 * m - 2, 3)

                                 3     

                           Next m

                           Text1.Text = c

                  End Sub

 

                  Private Function zh(s As String) As String

                           Dim i As Integer, n As Integer, p As Integer

                           p = 1

                           For i = 2 To 0 Step -1

                                       4     

                              p = p + 1

                           Next i

                           zh = Str(n)

                  End Function

 

2)        补充代码(2001春二(7))

         下面程序是把给定的16进制正整数转换为10进制数。

                  Option Explicit

 

                  Private Sub Form_Click()

                           Dim St As Integer Dem As Long

                           St=InputBox("输入一个十六进制数")

                           Dem=Convert(St)

                           Print St; ">="; Dem

                  End Sub

 

                  Private Function Convert(S As String)As Long

                           Dim N As Integer I As IntegerSubstring As String*1

                           Dim P As long K As LongAsc1 As Integer

                           N=  1  

                           P=16^N

                           For I=1 To N

                                    P=P/16

                                    Substring=  2  

                                    Select Case Substring

                                             Case "0" To "9"

                                                      K=K+P*Val(Substring)

                                             Case   3  

                                                      Asc1=Asc(Substring)-Asc("A")+10

                                                        4  

                                    End Select

                           Next I

                             5  

 

文章录入:杜斌    责任编辑:杜斌 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
     

    联 系 信 息
    QQ:88236621
    电话:15853773350
    E-Mail:malenurse@163.com
    免费发布招聘信息
    做中国最专业男护士门户网站
    最 新 热 门
    最 新 推 荐
    相 关 文 章
    没有相关文章
    专 题 栏 目

      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)                            【进男护士社区逛逛】
    姓 名:
    * 游客填写  ·注册用户 ·忘记密码
    主 页:

    评 分:
    1分 2分 3分 4分 5分
    评论内容:
  • 请遵守《互联网电子公告服务管理规定》及中华人民共和国其他各项有关法律法规。
  • 严禁发表危害国家安全、损害国家利益、破坏民族团结、破坏国家宗教政策、破坏社会稳定、侮辱、诽谤、教唆、淫秽等内容的评论 。
  • 用户需对自己在使用本站服务过程中的行为承担法律责任(直接或间接导致的)。
  • 本站管理员有权保留或删除评论内容。
  • 评论内容只代表网友个人观点,与本网站立场无关。