-
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
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
- C++. Podróż Po Języku - komentarz
Najnowsze wątki
- 2025-07-05 Shrek, wzrośnie cena prądu :-)
- 2025-07-05 Warszawa => Senior Frontend Developer (React + React Native) <=
- 2025-07-05 Środa Wielkopolska => SAP FI/CO Internal Consultant <=
- 2025-07-05 Środa Wielkopolska => SAP FI/CO Konsultant wewnętrzny <=
- 2025-07-06 Płacić za wodę ze studni
- 2025-07-06 Kolejny inżynier...
- 2025-07-05 UE ustępuje pod presją Trumpa. Socjaldemokraci: oddaliśmy miliardy
- 2025-07-04 od kiedy można obrażać Plastusia i do kiedy Batyra?
- 2025-07-05 UE ustępuje pod presją Trumpa. Socjaldemokraci: oddaliśmy miliardy
- 2025-07-03 Trybik
- 2025-07-04 Renault Symbioz
- 2025-07-04 Architektura IIIRP: Wyjątkowa, a prymitywniejsza niż stodoła pod zaborami
- 2025-07-04 Warszawa => International Freight Forwarder <=
- 2025-07-04 Wrocław => SAP ABAP Developer <=
- 2025-07-04 Warszawa => Mid/Senior IT Recruiter <=