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

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

 
Hledat
Vybavení pro Laser Game
Spuštěn Filmový magazín
Laser Game Brno
Pergoly a střechy Brno

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

Google       Google       12. 6. 2005       13 961×

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 Jak vést kvalitně tým v IT oboru: Naprogramujte si ty správné manažerské kvality

Jak vést kvalitně tým v IT oboru: Naprogramujte si ty správné manažerské kvality

Vedení týmu v oboru informačních technologií se nijak zvlášť neliší od jiných oborů. Přesto však IT manažeři čelí výzvě v podobě velmi rychlého rozvoje a tím i rostoucími nároky na své lidi. Udržet pozornost, motivaci a efektivitu týmu vyžaduje opravdu pevné manažerské základy a zároveň otevřenost a flexibilitu pro stále nové výzvy.

Reklama
Reklama
Obrázek ke článku Síla týmů se na home office může vytrácet. Odborníci radí, jak z pracovních omezení vytěžit maximum

Síla týmů se na home office může vytrácet. Odborníci radí, jak z pracovních omezení vytěžit maximum

Za poslední rok se podoba práce zaměstnanců změnila k nepoznání. Především plošné zavedení home office, které mělo být zpočátku jen dočasným opatřením, je pro mnohé už více než rok každodenní realitou. Co ale dělat, když se při práci z domova ztrácí motivace, zaměstnanci přestávají komunikovat a dříve fungující tým se rozpadá na skupinu solitérů? Odborníci na personalistiku dali dohromady několik rad, jak udržet tým v chodu, i když pracovní podmínky nejsou ideální.

Obrázek ke článku Konference: Moderní informační systémy podporují automatizaci

Konference: Moderní informační systémy podporují automatizaci

Současná situace v šíření onemocnění Covid-19 klade na řadu firem nové nároky a mnohé z nich jsou nyní více než kdy jindy závislé na nejmodernějších informačních technologiích. Proto i v oblasti podnikových informačních systémů vidíme rostoucí důraz na automatizaci nebo na důslednou integraci. Také o těchto trendech se bude mluvit na konferenci Firemní informační systémy, která se koná 24.9.2020 v pražském Kongresovém centru Vavruška na Karlově náměstí.

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