Mikähän olisi optimaalisin tapa tulostaa esimerkiksi 8-bittinen luku bittimuodossa?
Ajattelin tehdä silmukan, jossa olisi ensin maskina 0b1000000 ja se sitten naitettaisiin &-operaattorilla käsittelyssä olevaan 8-bittiseen lukuun. Jos tulos on 0, niin kyseinen bitti on nolla (tulostetaan vaikka printf():llä 0), ja muussa tapauksessa se olisi 1. Sitten shiftattaisiin maskia pykälän verran oikealle ja toistettaisiin hommaa lsb:hen saakka.
Vai onko olemassa joku yksinkertaisempi ja tehokkaampi tapa?
Luvun tulostaminen bitteinä
4
242
Vastaukset
- WituixMän
Joskus tein aikoinaan tuollaisen koodinpätkän mutta käyttöä sille ei juurikaan ole ollut.
Tulos tuli tekstinä tyyliin 10101101, lisäsin vielä vaihtoehdot v2 ja v3 joten
v1=teksti
v2=lukutaulukko
v3=merkkitaulukko
Muuttujat ja functiokutsu:
Dim dluku As ULong = 1234567
Dim BinT As String 'v1
'Dim BinI() As Short 'v2
'Dim BinC() As Char 'v3
BinT = ToBin(dluku) 'v1
'BinI = ToBin(dluku) 'v2
'BinC = ToBin(dluku) 'v3
ToBin-functio
Function ToBin(ByVal luku As ULong)
Dim btext As String = "" 'v1=teksti
'Dim bint(7) As Short 'v2=lukutaulukko
'Dim bchar(7) As Char 'v3=merkkitaulukko
Dim bm As ULong = 8 'bittien määrä
Dim vl As ULong = 0 'vertailuluku
Try
'selvitetään bittien määrä, 8,16,32 tai 64-bit
While vl < luku
vl = Math.Pow(2, bm)
If luku > vl Then bm = bm * 2 'jos ei riitä niin kerrotaan bittien määrä kahdella
If bm = 64 Then Exit While 'jos käyttää ULongon tilalla Long-muuttujaa niin 64 pitää vaihtaa 32:ksi
End While
'päivitetään v2 ja v3 tapauksissa muuttujat
'ReDim bint(bm - 1) v2
'ReDim bchar(bm - 1) v3
For i = 0 To bm - 1
'luetaan bitit takaa päin joten bitti joka on jakojäännös lisätään loppuun
btext = luku Mod 2 & btext 'v1
'bint(bm - 1 - i) = luku Mod 2 'v2
'bchar(bm - 1 - i) = Convert.ToString(luku Mod 2) 'v3
luku = Math.Floor(luku / 2) ' jaetaan kahdella seuraavaa bittiä varten, pyöristys alas
Next
Catch
MsgBox("Wituix män!!", MsgBoxStyle.Critical) 'noin käy jos on liian suuri luku
Return Nothing
Exit Function
End Try
'18446744073709551615 = suurin ULong
Return btext 'v1
'Return bint 'v2
'Return bchar 'v3
End Function
Kuten arvoisa lukija huomaa on koodi Visual Basicia jota nykyisin käytän Visual Studio 2012:lla.
Lopetin C :n käytön jo "valovuosia" sitten, aloitan sen uudelleen jos siihen löytyy hyvä syy. C# on joskus tarvinnut. - tietokoneinsinööri
Ehkäpä ei ole merkittävästi tehokkaampaa keinoa, jos verrataan eri lähestymistapojen
assembly-koodia, pakko käyttää (x86) SHR:ää/SHL:ää yms. ja vertailla vaikka lsb:tä/msb:tä AND:lla, kun mikroprosessorin rekisterit on nykyään vähintää 8-bittisiä tai sitten tallentaa ROM -muistiin 8-alkioinen taulukko, joka bitille oma alkio (0x80, 0x40, 0x20, 0x10, 0x08, 0x04, 0x02, 0x01) ja verrata niitä erikseen haluttuun lukuun. Muistin varaamisessa voi tulla eroa joskin merkitys suurempi ainoastaa rajoittuneiden resurssien ollessa käytössä (esim. ajetaan rinnakkain samaa ohjelmaa about 1000 kertaa).
Vai olisikohan jonkin prosessoriperheen käskykannassa konekielinen komento, joka tekisi sen vähemmillä kellojaksoilla (onko jollakin parempaa tietoa)? Tietenkin voit itse suunnitella FPGA/ASIC-prosessorin tähän tarkoitukseen.
https://en.wikipedia.org/wiki/Cycles_per_instruction - pcmuseo
Ei ehkä optimaalisin, mutta:
#include
void main(int argc,char *argv[])
{
unsigned char luku;
char tulos[]="00000000b";
char i=8;
if(argc<2)return;
luku=atoi(argv[1]);
printf("%d=0x%x=",luku,luku);
while(i--)
{
tulos[i]=luku&1?'1':'0';
luku>>=1;
}
printf("%s\n",tulos);
} - Jspsus
Mä laittsisin:
while(n!=0) {b=(n%2==0 ?"0": "1") b; n/2;}
n = kymmenkantainen luku
b = luku bitteinä
Tuossa ei myöskään väliä monikobittinen luku, koska osaa ottaa lyhimmän mukaan.
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
SDP haluaa LISÄÄ veroja bensa-autoille!
Sdp:n vaihtoehtobudjetti esittää polttomoottoriautoille lisää veroja Sdp esittää tuoreessa vaihtoehtobudjetissaan verot18617557Riikka se jytkytti BKT:stä nyt 0,3 prosenttia pois
Ja vain kolmessa kuukaudessa! Vuositasollahan tuo tarkoittaa reilun prosentin pudotusta. Pärjäisi varmaan lasketteluss4810071Vasemmistoaate on aatteista jaloin
Kaikki saavat ja kukaan ei jää ilman. Kuka tuollaista voisi vastustaa?1526144Antti Lindtman kiitti valtiovarainministeri Purraa
Ministeri Purra kertoi ottavasa vastuun EU:n alijäämämenettelyyn joutumisesta. Hän myös sanoi tietävänsä, että Lindtman463240Suomalaisten enemmistö on (ateisteja / fiksuja / sosialisteja)
Tai jokin noiden yhdistelmä, koska S-ryhmän markkinaosuus päivittäistavarakaupasta on yli 50 prosenttia.222929Brittiläinen vasemmistolehti: Sanna Marin oli vihdoin rehellinen
Nyt tulee pahasti lunta tupaan Seiskan tähtitytölle. Ex-pääministerin kirjaa arvostellaan latteuksista ja itsekehusta.342891"Purra löylytti oppositiota", sanoi naistoimittaja Pöllöraadissa
Kyllä, Purra tekee juuri sitä työtä mitä hänen tuossa asemassa pitää tehdä, hän antaa oppositiolle takaisin samalla mita592731Henkilökohtaisia paljastuksia Dubaista - Kohujulkkis Sofia Belorf on äitipuoli ja puoliso!
Tiesitkö, että Sofia on äitipuoli ja rakastava puoliso? Sofia Belorf saa oman sarjan, jossa seurataan hänen Bling Bling872675- 1401932
Alexander C. G. riisti demari-Veijolta arvonimen
"Stubb myönsi 66 arvonimeä ja peruutti yhden arvonimen. Presidentti Tarja Halonen myönsi Baltzarille kulttuurineuvoksen491921