Path: csiph.com!x330-a1.tempe.blueboxinc.net!newsfeed.hal-mli.net!feeder3.hal-mli.net!newsfeed.hal-mli.net!feeder1.hal-mli.net!border3.nntp.dca.giganews.com!Xl.tags.giganews.com!border1.nntp.dca.giganews.com!nntp.giganews.com!local2.nntp.dca.giganews.com!news.giganews.com.POSTED!not-for-mail NNTP-Posting-Date: Fri, 24 Jun 2011 12:32:20 -0500 From: Pete Becker Organization: Roundhouse Consulting, Ltd. Newsgroups: comp.lang.c++ Date: Fri, 24 Jun 2011 13:32:20 -0400 Message-ID: <2011062413322032750-pete@versatilecodingcom> References: <589f8b74-d065-44a5-ab9e-81e6a6fcd88b@v12g2000vby.googlegroups.com> <2a469bdc-e9e8-4629-b31b-00b569052409@gh5g2000vbb.googlegroups.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1; format=flowed Content-Transfer-Encoding: 8bit Subject: Re: (simple?) problem with multiplication User-Agent: Unison/2.1.4 Lines: 21 X-Usenet-Provider: http://www.giganews.com X-Trace: sv3-QrP35MY/CbgEPZEo+gNP+SQB8FTrBUoaaOzK1RjwYETAgfZGGien1ko4z4di5GJYXvd7vtiZvSUqzBN!AIzSZQSYrxnxxLxQBLqdh8l/xUsdzSwEv0kgE9p+ZyVJfEBJAJW2vlYb+/OZZAAPu+KfHFGF X-Complaints-To: abuse@giganews.com X-DMCA-Notifications: http://www.giganews.com/info/dmca.html X-Abuse-and-DMCA-Info: Please be sure to forward a copy of ALL headers X-Abuse-and-DMCA-Info: Otherwise we will be unable to process your complaint properly X-Postfilter: 1.3.40 X-Original-Bytes: 1848 Xref: x330-a1.tempe.blueboxinc.net comp.lang.c++:7125 On 2011-06-24 13:09:56 -0400, SG said: > In case this hasn't been mentioned already (I just skimmed this > thread): > > (a*b)%B = ((a%B)*(b%B))%B > Yes, but it doesn't solve the problem. :-( Suppose a*b overflows and that B is greater than both a and b. Then a%B is a, and b%B is b; then (a%B)*(b%B) is a*b, and it overflows. Another approach is brute force: write double-precision multiplication and division routines; not too hard, but involves tedious details; -- Pete Roundhouse Consulting, Ltd. (www.versatilecoding.com) Author of "The Standard C++ Library Extensions: a Tutorial and Reference (www.petebecker.com/tr1book)