-
21. Data: 2013-04-13 01:31:04
Temat: Re: zamiana liczby
Od: Edek <e...@g...com>
Dnia Wed, 10 Apr 2013 14:52:43 -0700 po głębokim namyśle firr kenobi
rzekł:
> W dniu środa, 10 kwietnia 2013 19:24:51 UTC+2 użytkownik Ministerstwo
> Propagandy napisał:
>> dobrze powiedziane, niestety oni dostają granty za "wiadomo co"...
>
> haha :-) !
Czyżby ktoś był zmuszony odmówić jak ładnie prosili?
--
Edek
-
22. Data: 2013-04-15 23:23:53
Temat: Re: zamiana liczby
Od: "Ireneusz Szpilewski" <i...@s...opole.pl>
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
-
23. Data: 2013-04-20 09:53:23
Temat: Re: zamiana liczby
Od: "Kamil" <n...@t...pl>
Użytkownik "identyfikator: 20040501" napisał:
> jak to szybko i skutecznie zrobić?
> tylko BARDZO UPRZEJMIE PROSZĘ nie flejmować...
Spadaj głupi trollu. Szybko i skutecznie.
BZPZDR
-
24. Data: 2013-04-20 09:55:29
Temat: Re: zamiana liczby
Od: "Kamil" <n...@t...pl>
Użytkownik "Ireneusz Szpilewski" napisał:
> Takie cos ponizej wysmazylem ...
> #include <stdio.h>
To jest asembler? Czy na tej grupie są juz same głupki?
BZPZDR
-
25. Data: 2013-04-20 10:04:34
Temat: Re: zamiana liczby
Od: "Ministerstwo Propagandy" <N...@g...pl>
> Spadaj głupi trollu. Szybko i skutecznie.
sam spadaj do europy pedale...