eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingzamiana liczby › Re: zamiana liczby
  • 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

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: