日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 芯聞號 > 充電吧
[導(dǎo)讀]? 計(jì)算機(jī)是采用二進(jìn)制存儲(chǔ)的,計(jì)算機(jī)的二進(jìn)制編碼方式也分為原碼,反碼,補(bǔ)碼方法。這是一個(gè)把十進(jìn)制數(shù)字轉(zhuǎn)換到它的二進(jìn)制原碼的算法,希望能給大家一些啟發(fā)吧!這個(gè)算法我是用VB6寫的,其中用到了函數(shù)遞歸調(diào)用

? 計(jì)算機(jī)是采用二進(jìn)制存儲(chǔ)的,計(jì)算機(jī)的二進(jìn)制編碼方式也分為原碼,反碼,補(bǔ)碼方法。這是一個(gè)把十進(jìn)制數(shù)字轉(zhuǎn)換到它的二進(jìn)制原碼的算法,希望能給大家一些啟發(fā)吧!這個(gè)算法我是用VB6寫的,其中用到了函數(shù)遞歸調(diào)用和函數(shù)可選參數(shù)(個(gè)人感覺功能和C++中的函數(shù)重載差不多)。
--------------------------------------------------------------------------------
Option Explicit
Option Base 1

Dim S() As String * 1, i As Integer

Public Function BinaryConvertA(ByVal iNum As Integer, Optional ByVal iLength As Integer = 8) As String
'//***************************************? Design By 0412Rainbow?**********************************************//
'功能:用于將一個(gè)二進(jìn)制數(shù)轉(zhuǎn)換為二進(jìn)制原碼,計(jì)算思想是除二取余,iNum為所要轉(zhuǎn)換的十進(jìn)制數(shù),iLength為機(jī)器字長(即二進(jìn)制數(shù)
'???? 的位數(shù)),可選,默認(rèn)傳遞8,iNum的轉(zhuǎn)換范圍-2^(n-1) 到 +2^(n-1),返回值為二進(jìn)制的字符串形式.
'說明:本算法可以很容易的轉(zhuǎn)換成除R取余,只要在函數(shù)中加個(gè)參數(shù)即可.另原碼簡介(引自程序員教程):設(shè)機(jī)器字長為n(即采用n個(gè)
'???? 二進(jìn)制位表示數(shù)據(jù)),則最高位是符號位,0表示正號,1表示負(fù)號;其余的n-1位表示數(shù)值的絕對值。
'函數(shù)調(diào)用 二進(jìn)制原碼 = BinaryConvertA(十進(jìn)制數(shù),二進(jìn)制字長)
'//*******************************************************************************************************************//

ReDim S(iLength) As String * 1
Dim sResult As String: i = 1: Dim j As Integer
If Abs(iNum) > 2 ^ (iLength - 1) Then
??? MsgBox "十進(jìn)制數(shù)表示溢出", , "進(jìn)制轉(zhuǎn)換算法"
??? Exit Function
End If

'修正當(dāng)十進(jìn)制數(shù)為0的bug,但只處理了+0的問題,并沒有特殊處理-0的問題,最好在調(diào)用函數(shù)之前進(jìn)行一個(gè)判斷
If CStr(iNum) = "0" Then
??? For j = 1 To iLength
??????? sResult = sResult & 0
??? Next
??? BinaryConvertA = sResult: Exit Function

End If

If Abs(iNum) <> iNum Then
?? S(iLength) = 1
Else
??? S(iLength) = 0
End If

Call ConvertToBinary(Abs(iNum), i)

For j = i + 1 To iLength - 1
??? S(j) = 0
??? 'Debug.Print j, S(j)
Next

For i = iLength To 1 Step -1
??? sResult = sResult & S(i)
??? 'Debug.Print sResult
Next
BinaryConvertA = sResult

End Function


Private Sub ConvertToBinary(ByVal iNums As Integer, ByVal iCount As Integer)
If iNums <> 1 Then
?? S(i) = iNums Mod 2
?? Debug.Print i, S(i)
?? i = i + 1
?? Call ConvertToBinary(iNums / 2, i)
Else
?? S(i) = 1
??
End If
End Sub

--------------------------------------------------------------------------------
函數(shù)調(diào)用范例:

新建一個(gè)工程,添加一個(gè)模塊,將上面的代碼復(fù)制到模塊中,在窗體中添加一個(gè)textbox,三個(gè)command控件,自己調(diào)整位置。

然后將下面的代碼復(fù)制到窗體的代碼頁中.

Private Sub Command1_Click()
Text1.Text = Text1.Text & BinaryConvertA(111) & vbCrLf

End Sub

Private Sub Command2_Click()
Text1.Text = Text1.Text & BinaryConvertA(-222, 9) & vbCrLf

End Sub

Private Sub Command3_Click()
Text1.Text = ""

End Sub

Private Sub Form_Load()
Text1.Text = ""
Command1.Caption = "第一種調(diào)用方式"
Command2.Caption = "第二種調(diào)用方式"
Command3.Caption = "&clear"
End Sub


--------------------------------------------------------------------------------

這樣就實(shí)現(xiàn)了函數(shù)的調(diào)用,需要說的還有,我沒有在函數(shù)中添加對調(diào)用參數(shù)類型的判斷,這個(gè)判斷應(yīng)該加到調(diào)用函數(shù)前,比如說,如果你調(diào)用的參數(shù)來自一個(gè)文本框的文本。那么,你在調(diào)用函數(shù)前要先判斷文本是否可以轉(zhuǎn)換到一個(gè)integer類型的整數(shù)(cInt函數(shù)),可以采用IsNumeric 函數(shù)進(jìn)行判斷文本中的內(nèi)容是否為數(shù),具體實(shí)現(xiàn)過程就很簡單了,在此就不多加解釋了。我會(huì)在接下來的日子里寫出反碼和補(bǔ)碼的代碼,也有可能給出C++版的代碼,如果對此有興趣,請關(guān)注我的BLOG!Thank you~


--------------------------------------------------------------------------------

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀
關(guān)閉