-
Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!newsfeed2.atman.pl!newsfeed.
atman.pl!news.task.gda.pl!not-for-mail
From: "Ireneusz Szpilewski" <i...@s...opole.pl>
Newsgroups: pl.comp.programming
Subject: Re: zamiana liczby
Date: Mon, 15 Apr 2013 23:23:53 +0200
Organization: CI TASK http://www.task.gda.pl/
Lines: 83
Message-ID: <o...@p...wgr612>
References: <kjsgog$lu7$1@node2.news.atman.pl> <op.wvaq0ku4wyk85p@localhost>
<7...@g...com>
NNTP-Posting-Host: 178.252.26.75.internetia.net.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=utf-8; format=flowed; delsp=yes
Content-Transfer-Encoding: Quoted-Printable
X-Trace: news.task.gda.pl 1366061029 13503 178.252.26.75 (15 Apr 2013 21:23:49 GMT)
X-Complaints-To: a...@n...task.gda.pl
NNTP-Posting-Date: Mon, 15 Apr 2013 21:23:49 +0000 (UTC)
User-Agent: Opera Mail/12.15 (Win32)
Xref: news-archive.icm.edu.pl pl.comp.programming:202599
[ ukryj nagłówki ]W dniu 10.04.2013 o 11:43 firr kenobi <p...@g...com> pisze:
> co do kodu to nie rozumiem tego kodu, jak to
> działa? - jedzie jakos po 32 bitach i co
> jakis czas mnozy przez dwa i costam porownuje?
Mniej wiecej wlasnie tak :-). Jak chcesz zamienic liczbe dwojkowa na
dziesietna to mozna wlasnie tak dzialac: zerujesz wynik, a potem
analizujesz bity liczby dwojkowej od najstarszego do najmlodszego i jesli
bit jest rowny 0, to mnozysz wynik razy 2, a jesli bit jest rowny 1, to
mnozysz wynik razy 2 i dodajesz 1. Np. dla liczby dwojkowej 1011 mamy:
wynik = 0
lewy bit == 1, więc wynik = 2 * wynik + 1 == 1
nastepny bit == 0, wiec wynik = 2 * wynik == 2
nastepny bit == 1, wiec wynik = 2 * wynik + 1 == 5
ostatni bit == 1, wiec wynik = 2 * wynik + 1 == 11
czyli dwojkowe 1011 == 11 dziesietnie
W tym moim algorytmie jeszcze chodzi o wyluskane odpowieniej grupy bitow z
zadanej liczby 32 bitowej, odpowiedzialnych za bajty, kilobajty, megabajty
lub gigabajty.
Liczba 32 bitowa, będąca rozmiarem pliku, ma ponizsza strukture bitów:
ggmmmmmmmmmmkkkkkkkkkkbbbbbbbbbb
gdzie b: grupa 10 bitow odpowiedzialnych za rozmiar w bajtach
k: grupa 10 bitow odpowiedzialnych za rozmiar w KB
m: grupa 10 bitow odpowiedzialnych za rozmiar w MB
g: grupa 2 bitow odpowiedzialnych za rozmiar w GB
Chodzi o zamiane na liczbe dziesietna pierwszej od lewej grupy bitow,
ktora zawiera chociaz jeden bit niezerowy (wykrycie takiego bitu oznaczamy
przez nadane zmiennej hit wartosci 1). Wynik bedzie "informatyczny" czyli
KB = 1024 B, MB = 1024*1204 B. Teraz napisze, co oznaczaja zmienne:
Zmienna power1024 ma wartosc:
3 dla bitu z grupy g,
2 dla bitu z grupy m,
1 dla bitu z grupy k,
0 dla bitu z grupy b,
ggmmmmmmmmmmkkkkkkkkkkbbbbbbbbbb
33222222222211111111110000000000 <- power1024
Zmienna bit10 oznacza numer bitu w ramach grupy bitow, liczony w lewo.
Poczatkowa wartosc to 1, bo zaczynamy analize bitow od lewej strony, a
grupa bitow typu g ma tylko 2 bity:
ggmmmmmmmmmmkkkkkkkkkkbbbbbbbbbb
10987654321098765432109876543210 <- bit10
Zmienna byte oznacza nr bajtu zadanej liczby 32-bitowej, czyli tak:
ggmmmmmmmmmmkkkkkkkkkkbbbbbbbbbb
33333333222222221111111100000000 <- byte
Jak juz wiesz, co znacza te zmienne, to powinno byc latwiej przesledzic,
jak dziala algorytm.
Irek
Następne wpisy z tego wątku
- 20.04.13 09:55 Kamil
- 20.04.13 09:53 Kamil
- 20.04.13 10:04 Ministerstwo Propagandy
Najnowsze wątki z tej grupy
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
Najnowsze wątki
- 2024-11-29 Dławik CM
- 2024-11-29 [OT] Lewe oprogramowanie
- 2024-11-29 Błonie => Sales Specialist <=
- 2024-11-29 Warszawa => IT Expert (Network Systems area) <=
- 2024-11-29 Warszawa => Ekspert IT (obszar systemów sieciowych) <=
- 2024-11-29 Warszawa => Head of International Freight Forwarding Department <=
- 2024-11-29 Białystok => Inżynier Serwisu Sprzętu Medycznego <=
- 2024-11-29 Pómpy ciepła darmo rozdajoo
- 2024-11-29 Białystok => Application Security Engineer <=
- 2024-11-29 Białystok => Programista Full Stack (.Net Core) <=
- 2024-11-29 Gdańsk => Software .Net Developer <=
- 2024-11-29 Wrocław => Key Account Manager <=
- 2024-11-29 Gdańsk => Specjalista ds. Sprzedaży <=
- 2024-11-29 Chrzanów => Specjalista ds. public relations <=
- 2024-11-27 Re: UseGalileo -- PRODUKTY I APLIKACJE UŻYWAJĄ JUŻ DZIŚ SYSTEMU GALILEO