EBK DATA STRUCTURES AND ALGORITHMS IN C
EBK DATA STRUCTURES AND ALGORITHMS IN C
4th Edition
ISBN: 9781285415017
Author: DROZDEK
Publisher: YUZU
bartleby

Videos

Expert Solution & Answer
Book Icon
Chapter 5, Problem 19E

Explanation of Solution

Von Koch snowflake using Recursive method:

  • A method calls itself is a recursive method.
  • In recursive function base case will stop recursion and return value instead of calling function.
  • In each recursive call each side is divided into three sides. Each side has length of one by third of previous one.
  • Three new sides are drawn by turn line to left by “600”, turn right by “1200” and turn left by “600”.

Refer program in Figure 5.6 of textbook and include the following code in the given program to draw the cross.

Function to draw cross:

//Recursive function to draw side of cross

void drawSideofCross(double sidde, int levell)

{

  //If level is 0

  if (levell == 0)

  {

  //Calculate value of x cordinate

  pt.x = int(cos(angle*PI/180)*sidde) + currPt.x;

  //Calculate value of y cordinate

  pt.y = int(sin(angle*PI/180)*sidde) + currPt.y;

  pen->LineTo(pt);

  //Set x cordinate of of current point

  currPt.x = pt.x;

  //Set y cordinate of of current point

  currPt.y = pt.y;

  }

  //If level is not 0

  else

  {

/*Call recursive function drawSideofCross() with prameters (sidde/3) and (levell-1)*/

drawSideofCross(sidde/3,levell-1);

//Rotate 90 degree to left

left (90);

/*Call recursive function drawSideofCross() with parameters (sidde/3) and (levell-1)*/

  drawSideofCross(sidde/3,levell-1);

  //Rotate 90 degree to right

  right(90);

/*Call recursive function drawSideofCross() with parameters (sidde/3) and (levell-1)*/

drawSideofCross(sidde/3,levell-1);

//Rotate 90 degree to right

right(90);

/*Call recursive function drawSideofCross() with parameters (sidde/3) and (levell-1)*/

  drawSideofCross(sidde/3,levell-1);

  //Rotate 90 degree to left

  left (90);

/*Call recursive function drawSideofCross() with parameters (sidde/3) and (levell-1)*/

  drawSideofCross(sidde/3,levell-1);

}

}

//Function to draw cross

void drawCross()

{

/*Call recursive function drawSideofCross() with parameters (side) and (level)�...

Blurred answer
Students have asked these similar questions
The images I have uploaded are the part 1 to 4 and questions below are continue on the questions uploaded 5. C++ Class Template with Method Stubs #pragma once #include <iostream> #include <string> #include <stdexcept> #include <vector>   template <typename T> class HashTable { private:     struct Entry {         std::string key;         T value;         bool isOccupied;         bool isDeleted;         Entry() : key(""), value(), isOccupied(false), isDeleted(false) {}     };       Entry* table;     size_t capacity;     size_t size;     double loadFactorThreshold;           size_t customHash(const std::string& key) const {         size_t hash = 5381;         for (char c : key) {             hash = ((hash  <<  5) + hash)  +  c;         }         return hash;     }       size_t probe(const std::string& key, bool forInsert = false) const;     void resize();   public:     // Constructor     HashTable(size_t initialCapacity = 101);         // Big…
this project is NOT for graded(marks) purposes, please help me with the introduction. give me answers for the project. i will include an image explaining everything about the project.
Java Graphics (Bonus In this lab, we'll be practicing what we learned about GUIs, and Mouse events. You will need to implement the following: A GUI with a drawing panel. We can click in this panel, and you will capture those clicks as a Point (see java.awt.Point) in a PointCollection class (you need to build this). The points need to be represented by circles. Below the drawing panel, you will need 5 buttons: O о о ○ An input button to register your mouse to the drawing panel. A show button to paint the points in your collection on the drawing panel. A button to shift all the points to the left by 50 pixels. The x position of the points is not allowed to go below zero. Another button to shift all the points to the right 50 pixels. " The x position of the points cannot go further than the You can implement this GUI in any way you choose. I suggest using the BorderLayout for a panel containing the buttons, and a GridLayout to hold the drawing panel and button panels. Regardless of how…
Knowledge Booster
Background pattern image
Computer Science
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
SEE MORE QUESTIONS
Recommended textbooks for you
Text book image
C++ Programming: From Problem Analysis to Program...
Computer Science
ISBN:9781337102087
Author:D. S. Malik
Publisher:Cengage Learning
Text book image
EBK JAVA PROGRAMMING
Computer Science
ISBN:9781305480537
Author:FARRELL
Publisher:CENGAGE LEARNING - CONSIGNMENT
Text book image
C++ for Engineers and Scientists
Computer Science
ISBN:9781133187844
Author:Bronson, Gary J.
Publisher:Course Technology Ptr
Text book image
COMPREHENSIVE MICROSOFT OFFICE 365 EXCE
Computer Science
ISBN:9780357392676
Author:FREUND, Steven
Publisher:CENGAGE L
Text book image
EBK JAVA PROGRAMMING
Computer Science
ISBN:9781337671385
Author:FARRELL
Publisher:CENGAGE LEARNING - CONSIGNMENT
Text book image
Programming Logic & Design Comprehensive
Computer Science
ISBN:9781337669405
Author:FARRELL
Publisher:Cengage
Java random numbers; Author: Bro code;https://www.youtube.com/watch?v=VMZLPl16P5c;License: Standard YouTube License, CC-BY