-
Path: news-archive.icm.edu.pl!news.gazeta.pl!not-for-mail
From: "Wojciech \"Spook\" Sura" <spook"mad@hatter"op.pl>
Newsgroups: pl.comp.programming
Subject: Porównywanie ułamków zwykłych
Date: Tue, 21 Sep 2010 11:45:26 +0200
Organization: "Portal Gazeta.pl -> http://www.gazeta.pl"
Lines: 72
Message-ID: <op.vjdmp0xe8x7o78@notebook>
NNTP-Posting-Host: dynamic-78-8-44-83.ssp.dialog.net.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=iso-8859-2; format=flowed; delsp=yes
Content-Transfer-Encoding: Quoted-Printable
X-Trace: inews.gazeta.pl 1285062324 27684 78.8.44.83 (21 Sep 2010 09:45:24 GMT)
X-Complaints-To: u...@a...pl
NNTP-Posting-Date: Tue, 21 Sep 2010 09:45:24 +0000 (UTC)
X-User: spoko_ws
X-Antivirus: avast! (VPS 100920-1, 2010-09-20), Outbound message
X-Antivirus-Status: Clean
User-Agent: Opera Mail/10.62 (Win32)
Xref: news-archive.icm.edu.pl pl.comp.programming:186928
[ ukryj nagłówki ]Witam!
Zastanawiam się, w jaki sposób porównywać ułamki zwykłe?
Przypuśćmy, że mam dane dwa ułamki, a/b i c/d. Chcę sprawdzić, czy są
równe.
1. Metoda brutalna:
float f1 = a/b;
float f2 = c/d;
return f1 == f2;
f1 == f2 wygląda jak herezja, ale weźmy pod uwagę, że operacje
zmiennoprzecinkowe są wykonywane deterministycznie i jeśli ułamki
faktycznie są równe, warunek będzie spełniony. Niestety, nie mamy tu
równoważności: być może bowiem uda się znaleźć inny ułamek zwykły, który
da w wyniku taką samą liczbę zmiennoprzecinkową, ale wynikłą z
niedoskonałości zapisu zmiennoprzecinkowego. Najwyraźniej więc metoda nie
jest zbyt skuteczna.
2. Wspólny mianownik
int tmpGCD = GCD(b, c);
return (a * (d / tmpGCD)) == (c * (b / tmpGCD));
Problem pojawi się wówczas, gdy złośliwie podrzucimy dwa ułamki o dużych
mianownikach, których GCD wynosi 1, na przykład 1/2147483629 i
1/2147483647. Ich wspólnym mianownikiem jest 4611685977625198592, co
oczywiście wykracza poza zakres long int. Co więcej, jedynym znanym mi
sposobem na sprawdzenie, czy iloczyn dwóch liczb mieści się w zakresie
inta jest przypisanie go do zmiennej typu double i porównanie z
największym możliwym intem wyciągniętym z std::limits. Nie jest to zbyt
wydajne rozwiązanie...
Czy macie może jakiś lepszy pomysł?
Pozdrawiam -- Spook.
--
! ._______. Warning: Lucida Console sig! //) !
! || spk || www.spook.freshsite.pl / _ """*!
! ||_____|| spook at op.pl / ' | ""!
! | ___ | tlen: spoko_ws gg:1290136 /. __/"\ '!
! |_|[]_|_| May the SOURCE be with you! \/) \ !
Następne wpisy z tego wątku
- 21.09.10 09:56 Tomasz Kaczanowski
- 21.09.10 10:15 Mariusz Kruk
- 21.09.10 10:20 Mariusz Marszałkowski
- 21.09.10 11:17 nightwatch77
- 21.09.10 11:31 Wojciech \"Spook\" Sura
- 21.09.10 11:32 Wojciech \"Spook\" Sura
- 21.09.10 11:35 Wojciech \"Spook\" Sura
- 21.09.10 11:37 Tomasz Kaczanowski
- 21.09.10 11:40 Wojciech \"Spook\" Sura
- 21.09.10 11:42
- 21.09.10 11:47 Tomasz Kaczanowski
- 21.09.10 11:59 Mariusz Kruk
- 21.09.10 12:05 Mateusz Ludwin
- 21.09.10 12:14 Marcin 'Qrczak' Kowalczyk
- 21.09.10 13:29 Mariusz Marszałkowski
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-12-19 Kamerka sam. na tył
- 2024-12-20 Jak być bezpiecznym z Li-Ion?
- 2024-12-19 Fujitsu LIFEBOOK E746
- 2024-12-19 Katowice => Administrator IT - Systemy Operacyjne i Wirtualizacja <=
- 2024-12-19 Warszawa => Junior Account Manager <=
- 2024-12-19 Katowice => Administrator IT - Operating Systems and Virtualization <=
- 2024-12-19 Warszawa => Developer .NET (mid) <=
- 2024-12-19 Wrocław => Business Development Manager - Network and Network Securit
- 2024-12-19 Katowice => Full Stack web developer (obszar .Net Core, Angular6+) <=
- 2024-12-19 Olsztyn => Sales Specialist <=
- 2024-12-19 Żerniki => Specjalista ds. Employer Brandingu <=
- 2024-12-19 policja pomaga
- 2024-12-19 Kolejny biegły
- 2024-12-19 Taka ciekawostka skrzyżowaniowa
- 2024-12-19 koniki obsiadły kolejki i numerki