Ask Question, Ask an Expert

+61-413 786 465

info@mywordsolution.com

Ask Computer Engineering Expert

For each of the following problems, write a program or a program segment that performs the specified action.Each problem refers to class Polygon (Fig. L 11.15). This class contains a dynamically allocated array of x-coordinates and a dynamically allocated array of y-coordinates. These coordinates store the polygon's vertices. The Polygon constructor takes the initial vertex for the Polygon.

1 // Coding Exercises: Polygon.cpp
2 // class Polygon definition
3 #include
4 using std::ostream;
5 using std::endl;
6
7class Polygon
8 {
9 public:
10 Polygon( int = 0, int = 0 );
11 ~Polygon();
12
13 void addVertex( int, int );
14 int getNumVertices() const;
15 private:
16 int *xPts;
17 int *yPts;
18 int numVertices;
19 }; // end class Polygon
20
21 // default constructor
22 Polygon::Polygon( int x, int y )
23 {
24 xPts = new int[ 1 ];
25 yPts = new int[ 1 ];
26
27 xPts[ 0 ] = x;
28 yPts[ 0 ] = y;
29 numVertices = 1;
30 } // end class Polygon constructor
31
32 // destructor
33 Polygon::~Polygon()
34 {
35 delete [] xPts;
36 delete [] yPts;
37 } // end class Polygon destructor
38
39 // function addVertex definition
40 void Polygon::addVertex( int x, int y )
41 {
42 int *copyX = new int[ numVertices + 1 ];
43 int *copyY = new int[ numVertices + 1 ];
44
45 for ( int i = 0; i < numVertices; i++ )
46 {
47 copyX[ i ] = xPts[ i ];
48 copyY[ i ] = yPts[ i ];
49 } // end for
50
51 copyX[ numVertices ] = x;
52 copyY[ numVertices ] = y;
53
54 delete [] xPts;
55 delete [] yPts;
56
57 xPts = copyX;
58 yPts = copyY;
59 ++numVertices;
60 } // end function addVertex
61
62 // function getNumVertices
63 int Polygon::getNumVertices() const
64 {
65 return numVertices;
66 } // end function getNumVertices
1. Overload the stream-insertion operator << to output a Polygon object. The prototype for the << operator is
as follows:
ostream &operator<<( ostream &, const Polygon & );
2. Create a copy constructor for class Polygon. The prototype for the copy constructor is as follows:
Polygon( Polygon * );
3. Overload the == operator to compare two Polygons for equality. This member function should return a
boolean value. The prototype for the == operator is as follows:
bool operator==( Polygon & );
4. Overload the = operator to assign one Polygon object to another. This member function should return a const reference to the Polygon object invoking the member function. This member function also should test for self assignment. The prototype for the = operator is as follows:
const Polygon &operator=( const Polygon & );
5. Write a test program that does the follows: 
a. Get user input to create a polygon called polygon1. You can do this by first asking the user for the number of vertices in the polygon and then asking for the (x,y) pairs for each vertex. 
b. Output the polygon1 using your overloaded << operator function
c. Use the copy constructor to create another polygon called polygon2. 
d. Output polygon2
e. Ask the user to input another polygon called polygon3. 
f. Use your equality operator to compare polygon1 and polygon3. Output the result. 
g. Create a new polygon called polygon4 using the default constructor
h. Assign polygon3 to polygon4 using your overloaded assignment operator function. 
i. Output polygon4.

Computer Engineering, Engineering

  • Category:- Computer Engineering
  • Reference No.:- M9639925

Have any Question?


Related Questions in Computer Engineering

Explain a business process you are familiar with describe

Explain a business process you are familiar with. Describe how a computer-based information system is related (or used) in this business process. Explain how a computer-based information systems can improve the efficienc ...

How much work energy must you do to lift 1 tonne 1000 kg of

How much work energy must you do to lift 1 tonne (1000 kg) of coal from a depth of 500 m to the surface? What fraction of the heat energy in that coal was this? This is a simple calculation of one part of the emergy to t ...

Question suppose you are stranded on a desert island on

Question : Suppose you are stranded on a desert island on which queues are plentiful, but you need a stack. How can you implement a stack using two queues? What is the big-Oh running time of the stack operations?

Submit an annotated bibliography that includes the

Submit an annotated bibliography that includes the following: At least one resource from each of the following categories: Culture-specific information about your own culture Articles about a tradition, value, or belief ...

Of 144 single women 41 had breast cancer 209 who were

Of 144 single women 41% had breast cancer, 209 who were married 52.2% had breast cancer and of 89 life bing with family 59.6% had breast cancer. Find the p value for the relationship?

Question what are the server-side attacks what are the

Question : What are the server-side attacks? What are the techniques a developer can employ to minimize these attacks? The response must be typed, single spaced, must be in times new roman font (size 12) and must follow ...

In recreational mathematics a magic square is an

In recreational mathematics, a magic square is an arrangement of distinct numbers (i.e. each number is used once usually integers, in a square grid, where the numbers in each row and in each column, and the numbers in th ...

1 what would be the purpose for a user to protect a

1. What would be the purpose for a user to protect a file from "read" or "write" access by other users? 2. Is there a reason why it would be safer for administrators to use two different accounts when working with a comp ...

Question suppose users share a 2 mbps link also suppose

Question : Suppose users share a 2 Mbps link. Also suppose each user transmits continuously at 1 Mbps when transmitting, but each user transmits only 20 percent of the time. When a circuit switching is used, how many use ...

Sam smartypants likes how splitting the problem up into

Sam Smartypants likes how splitting the problem up into halves in merge sort reduces the sorting problem from O(n 2 ) to O(n lg n). He decides that splitting the array into thirds will make things even better. That is, h ...

  • 4,153,160 Questions Asked
  • 13,132 Experts
  • 2,558,936 Questions Answered

Ask Experts for help!!

Looking for Assignment Help?

Start excelling in your Courses, Get help with Assignment

Write us your full requirement for evaluation and you will receive response within 20 minutes turnaround time.

Ask Now Help with Problems, Get a Best Answer

Why might a bank avoid the use of interest rate swaps even

Why might a bank avoid the use of interest rate swaps, even when the institution is exposed to significant interest rate

Describe the difference between zero coupon bonds and

Describe the difference between zero coupon bonds and coupon bonds. Under what conditions will a coupon bond sell at a p

Compute the present value of an annuity of 880 per year

Compute the present value of an annuity of $ 880 per year for 16 years, given a discount rate of 6 percent per annum. As

Compute the present value of an 1150 payment made in ten

Compute the present value of an $1,150 payment made in ten years when the discount rate is 12 percent. (Do not round int

Compute the present value of an annuity of 699 per year

Compute the present value of an annuity of $ 699 per year for 19 years, given a discount rate of 6 percent per annum. As