Prevádzanie medzi číselnými sústavami
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama

Prevádzanie medzi číselnými sústavamiPrevádzanie medzi číselnými sústavami

 
Hledat
Moderní platforma pro vytvoření vašeho nového webu – Wix.com.
Nyní už můžete mít web zdarma.
Vybavení pro Laser Game
Spuštěn Filmový magazín
Laser Game Brno

Prevádzanie medzi číselnými sústavami

Google       Google       12. 6. 2005       12 561×

Keď som pred pár týždňami robil kalkulačku, ktorá podporuje prevody medzi číselnými sústavami bol som velmi prekvapený, keď som vo Visual Basicu nenašiel skoro žiadne funkcie na tieto prevody. Jedinú funkciu čo som našiel je funkcia Hex. Táto funkcia slúži na prevod z desiatkovej do šestnástkovej (hexadecimálnej) sústavy. Kedže som potreboval aj iné funkcie, tak mi neostávalo nič iné, ako naprogramovať si ich. Rozhodol som sa napísať ich tu, lebo sa môžu hodiť každému programátorovi...

Reklama
Reklama

Ako som už spomínal, na prevedenie z desiatkovej do hexadecimálnej slúži príkaz Hex. Pri prevedení z binárnej do hexadecimálnej treba najskôr previesť číslo do desiatkovej a až potom do hexadecimálnej. Funkcie na prevedenie do osmičkovej sústavy som sem nenapísal, lebo táto sústava sa velmi nepoužíva. Ale ak by mal niekto záujem tak mu ich môžem poslať.

Z desiatkovej do binárnej sústavy:

Function DecBin(Cislo As Long) As String
Dim i As Integer
While Cislo <> 0
DecBin = Cislo Mod 2 & DecBin
If Cislo Mod 2 = 0 Then
Cislo = Cislo / 2
Else
Cislo = (Cislo - 1) / 2
End If
Wend
End Function

Msgbox DecBin(25)

Z binárnej do desiatkovej sústavy:

Function BinDec(Cislo As String) As Long
Dim i As Integer
Dim X as Long
For i = 0 To Len(Cislo) - 1
If Right(Cislo, 1) = "0" Then X = X + 0 * 2 ^ i
If Right(Cislo, 1) = "1" Then X = X + 1 * 2 ^ i
Cislo = Left(Cislo, Len(Cislo) - 1)
Next i
BinDec = X
End Function

MsgBox BinDec(10011)

Z hexadecimálnej do desiatkovej:

Function HexDec(Cislo As String) As Long
Dim i As Integer
Dim X as Long
Cislo = LCase(Cislo)
For i = 0 To Len(Cislo) - 1
If Right(Cislo, 1) = "a" Then X = X + 10 * 16 ^ i
If Right(Cislo, 1) = "b" Then X = X + 11 * 16 ^ i
If Right(Cislo, 1) = "c" Then X = X + 12 * 16 ^ i
If Right(Cislo, 1) = "d" Then X = X + 13 * 16 ^ i
If Right(Cislo, 1) = "e" Then X = X + 14 * 16 ^ i
If Right(Cislo, 1) = "f" Then X = X + 15 * 16 ^ i
If Right(Cislo, 1) < 10 Then X = X + Right(Cislo, 1) * 16 ^ i
Cislo = Left(Cislo, Len(Cislo) - 1)
Next i
HexDec = X
End Function

Msgbox HexDec("4f2b")






×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

3 názory  —  3 nové  
Hlasování bylo ukončeno    
0 hlasů
Google
Autor programuje ve VB, mezi jeho další koníčky patří fyzika a matematika.

Nové články

Obrázek ke článku Hackathon Paralelní Polis odkryl nedostatky u projektu eObčanka

Hackathon Paralelní Polis odkryl nedostatky u projektu eObčanka

Paralelní Polis, nezisková organizace postavená na idejích svobody, nezávislosti a inovativního rozvoje společnosti, zorganizovala Hackathon s názvem eObčanka, jehož cílem bylo ověřit bezpečnost státního projektu elektronických průkazů a otevřít jej pro veřejnost. eObčanka je občanský průkaz s kontaktním elektronickým čipem, který umožňuje online prokazování totožnosti a uložení kvalifikovaných a autentizačních certifikátů. 

Reklama
Reklama
Obrázek ke článku Digitální nomád – nonstop na cestách a práce odkudkoliv

Digitální nomád – nonstop na cestách a práce odkudkoliv

Jak skloubit pracovní a osobní život je tématem, které řeší stále více lidí. Mladí více než kdy předtím kladou důraz na svůj osobní čas a nechtějí sedět od brzkého rána do pozdního večera v práci. Stále více lidí hledá způsob, jak si vydělat potřebné peníze a zároveň se bavit a trávit svůj čas smysluplně. 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032019 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý