Solved

Pythagorean Triples

Posted on 1997-03-06
5
582 Views
Last Modified: 2008-03-10

2.55      (Pythagorean Triples) A right triangle can have sides that are all integers.  The set of three integer values for the sides of a right triangle is called a Pythagorean triple.  These three sides must satisfy the relationship that the sum of the squares of two of the sides is equal to the square of the hypotenuse.  Find all Pythagorean triples for side l, side2, and the hypotenuse all no larger than 500.  Use a triple-nested for-loop that tries all possibilities.  This is an example of "brute force" computing.  You will learn in more advanced computer science courses that there are large numbers of interesting problems for which there is no known algorithmic approach other than using sheer brute force.

0
Comment
Question by:fondue
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
5 Comments
 
LVL 4

Expert Comment

by:jos010697
ID: 1162277
Is this a homework problem?
0
 
LVL 2

Accepted Solution

by:
Slarti earned 10 total points
ID: 1162278
#include <iostream.h>
int main()
{
 int a,b,c;
 for(a=1;a<500;a++)
  for(b=a;b<500;b++)
   for(c=b;c<500;c++)
    if(a*a+b*b==c*c)
     cout<<a<<","<<b<<","<<c<<endl;
 return 0;
}
0
 

Expert Comment

by:bc022297
ID: 1162279
since 500 * 500 = 250000, you will have to use long ints, otherwise the above code won't work.


0
 

Expert Comment

by:bc022297
ID: 1162280
since 500 * 500 = 250000, you will have to use long ints, otherwise the above code won't work.


0
 
LVL 84

Expert Comment

by:ozo
ID: 1162281
Just so we don't give the impression that there is no known algorithmic approach other than using sheer brute force for this problem:

for( s=1; s<23; s++){
    for( t=s+1; (c = t*t + s*s) < 500; t++ ){
      a = t*t - s*s; b = 2*s*t;
        cout<<a<<","<<b<<","<<c<<endl;
    }
}
 
0

Featured Post

Free Tool: IP Lookup

Get more info about an IP address or domain name, such as organization, abuse contacts and geolocation.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

In days of old, returning something by value from a function in C++ was necessarily avoided because it would, invariably, involve one or even two copies of the object being created and potentially costly calls to a copy-constructor and destructor. A…
This article will show you some of the more useful Standard Template Library (STL) algorithms through the use of working examples.  You will learn about how these algorithms fit into the STL architecture, how they work with STL containers, and why t…
The goal of the video will be to teach the user the concept of local variables and scope. An example of a locally defined variable will be given as well as an explanation of what scope is in C++. The local variable and concept of scope will be relat…
The viewer will learn additional member functions of the vector class. Specifically, the capacity and swap member functions will be introduced.

705 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question