eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingPorównywanie ułamków zwykłych › Re: Porównywanie ułamków zwykłych
  • Path: news-archive.icm.edu.pl!news.icm.edu.pl!news.nask.pl!news.nask.org.pl!newsfeed0
    0.sul.t-online.de!t-online.de!border2.nntp.dca.giganews.com!nntp.giganews.com!p
    ostnews.google.com!j30g2000vbr.googlegroups.com!not-for-mail
    From: Mariusz Marszałkowski <m...@g...com>
    Newsgroups: pl.comp.programming
    Subject: Re: Porównywanie ułamków zwykłych
    Date: Wed, 22 Sep 2010 18:21:16 -0700 (PDT)
    Organization: http://groups.google.com
    Lines: 33
    Message-ID: <0...@j...googlegroups.com>
    References: <op.vjdmp0xe8x7o78@notebook> <i7ar1d$vhr$1@news.onet.pl>
    <op.vjeimq0o8x7o78@notebook>
    NNTP-Posting-Host: 89.229.34.123
    Mime-Version: 1.0
    Content-Type: text/plain; charset=ISO-8859-2
    Content-Transfer-Encoding: quoted-printable
    X-Trace: posting.google.com 1285204876 13591 127.0.0.1 (23 Sep 2010 01:21:16 GMT)
    X-Complaints-To: g...@g...com
    NNTP-Posting-Date: Thu, 23 Sep 2010 01:21:16 +0000 (UTC)
    Complaints-To: g...@g...com
    Injection-Info: j30g2000vbr.googlegroups.com; posting-host=89.229.34.123;
    posting-account=xjvq9QoAAAATMPC2X3btlHd_LkaJo_rj
    User-Agent: G2/1.0
    X-HTTP-UserAgent: Mozilla/5.0 (Windows; U; Windows NT 5.1; pl; rv:1.9.2.10)
    Gecko/20100914 Firefox/3.6.10,gzip(gfe)
    Xref: news-archive.icm.edu.pl pl.comp.programming:186962
    [ ukryj nagłówki ]

    On 21 Wrz, 23:14, "Wojciech \"Spook\" Sura" <spook"mad@hatter"op.pl>
    wrote:

    > Dodam jeszcze, że nie satysfakcjonuje mnie wykorzystanie typu o większej  
    > precyzji, np. long long int. Równie dobrze możemy przyjąć, że licznik i  
    > mianownik są typu long long int i że mianowniki są z górnej granicy tego  
    > zakresu.

    Hmmm...
    Mamy sprawdzić czy a/b - c/d == 0.
    A jakby rozbić?
    x = polowa_bitow

    a1 = a & ((1<<x)-1)
    a2 = a >> x;
    itd...

    wtedy mamy coś w rodzaju
    ( a1 + (a2<<x) ) * ( d1 + (d2<<x) ) - ( b1 + (b2<<x) ) * ( c1 +
    (c2<<x) ) == 0

    po lewej stronie różnicy masz cztery iloczyny które na
    pewno nie przekroczą zakresu i po prawej cztery iloczyny
    które nie przekroczą zakresu.

    wystarczy dopracować szczegóły, tzn umiejętnie porównać te
    cztery iloczyny i powinno działać poprawnie na każdym typie.


    Pozdrawiam

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: