Determine the exact number of statements

Assignment Help JAVA Programming
Reference no: EM131563158

Programs must be written in Java.

If you are using Eclipse (or similar development environment), do not submit the workspace (project). Hand in only those files identified in Section 5. Export your .java source files from the workspace and submit only the .java files.

No late assignments will be accepted. See the course syllabus for the full late assignment policy for this class.

Background

Timing Analysis

Questions 1 through 10 in Section 3 concern timing analysis. These questions are not programming questions and should be submitted in one of the acceptable document formats listed above.

Arrayed Trees

Question 11 is about a bounded binary tree implementation. You should remember binary trees from CMPT 115 (or similar course) - they are trees in which each node has at most two children. What you probably didn't know is that binary trees can be stored using an array, rather than a linked structure. In such an array, the contents of the root node are stored in offset 1 of the array (offset 0 is unused). The contents of the children of the node whose contents are stored at offset i are stored at offset 2i and 2i + 1, respectively. Thus, the left child of the root is at offset 2 1 = 2, the right child of the root is at offset 2 1 + 1 = 3, the left child of the left child of the root is at offset 2 2 = 4, and so on. The parent of the node whose contents are at offset i, is at offset i/2 (integer division). Thus, the parent of node at offset 7 is at offset 3.

Question 1 ():

Suppose the exact time required for an algorithm A is given by:

TA(n) = 1234n + 19n3 + 99 + 27n5.5(log2n) + 42√n

(a) Which of the following statements are true?
1. Algorithm A is O(log n)
2. Algoirthm A is O(n)
3. Algoirthm A is O(n3)
4. Algoirthm A is O(2n )
(b)Give the correct time complexity for A in big-Θ notation.

Question 2 ():

For each of the following functions, give the tightest upper bound chosen from among the usual simple functions listed in Section 4.5 of the course readings. Answers should be expressed in big-O notation.

(a)  f1(n) = 12nlog2n + n2log2n + 2n/4200

(b)  f3(n) = n2log2n2 + 8n3 + log2(2n)

(c)  f2(n) = 4n0.5 + log2n/n + 1234

Question 3 ():

If possible, simplify the following expressions. Hint: See slide 11 of topic 4 of the lecture slides!
(a) O(n2) + O (log n) + O (n log n)
(b) O(2n) O(n2)
(c) 42O (n log n) + 18O(n3)
(d) O (n2log2 n2) + O (m) (yes, that's an ‘m', not a typo; note that m is independent of n)

Question 4: Consider the function f (n) = 2n3 + 5n2 + 42. Use the definition of big-O to prove that f (n) ? O(n3).

Question 5 :

Consider the function g(n) = 12n2 log n2 + 6n + 42. Use the definition of big-O to prove that g(n) ∈ O(n2 log n2).

Question 6 :

Consider again the function g(n) = 12n2 log n2 + 6n + 42. Use the definition of big-O to prove that g(n) is not in O(n).

Question 7 ():

Consider the following Java code fragment:

// Print out all ordered pairs of numbers between 1 and n for (i = 1; i <= n; i++) { for (j = 1; j <= n; j++)
{
System .out. println ( i + ", " + j) ; }
}

(a) Determine the exact number of statements (i.e. the statement counting approach) that are executed when we run this code fragment as a function of n. Show all of your calculations.

(b) Express the function you obtained in part a) in big-Θ notation.

Question 8 ():

Consider the following pseudocode:

Algorithm roundRobinTournament (a)
This algorithm generates the list of matches that must be
played in a round - robin pirate - dueling tournament (a tournament where each pirate duels each other pirate exactly once).

a is an array of strings containing names of entrants into a tournament n = a.length for i = 0 to n-1 for j = i+1 to n-1
print a[i] + " duels " + a[j] + ", Yarrr!"
(a) Determine the exact number of statements (i.e. use the statement counting approach that are executed by the above algorithm. Express your answer as a function of n. Show all your calculations.

(b) Express the function you obtained in part a) in big-Θ notation.

Question 9 ():

Consider the following pseudocode:

Algorithm moveDown (a) a is an array of numbers int i = 1
n = a.length
while (a[i] > a[2*i] || a[i] > a[2*i+1]) && 2*i+1 < n) if a[2*i] >= a[2*i +1]
largest = 2*i

else

temp = a[i]

largest = 2*i + 1

a[i] = a[largest] a[largest] = temp i = largest
(a) Determine the exact number of statements (i.e. use the statement counting approach) that are executed during one iteration of the while loop in the worst case. Your answer should be expressed in terms of n (the length of the array) Show all calculations.

(b) Determine the exact number of times the while loop executes in the worst case.

(c) Determine the exact number of statements executed in the worst case by the whole algorithm.

(d) Identify an Active Operation

(e) Determine the exact number of times the active operation is executed.

(f) Express the answers to parts c) and e) in big-O notation.

Question 10:

Your task is to write a Java class called ArrayedBinaryTreeWithCursors280<I> which extends and implements the abstract class ArrayedBinaryTree280<I> (provided in the lib280-asn2.tree package as part of lib280-asn2). This week's lab will also talk more about array-based trees.

Some of the work of implementing ArrayedBinaryTreeWithCursors280<I> has already been done.

There are several methods in defined in ArrayedBinaryTreeWithCursors280<I> which are defined but not implemented; these are marked with //TODO comments. Note that ArrayedBinaryTreeWithCursors280<I> also implements the interfaces Dict280<I> and Cursor280<I>. There are several missing methods re- quired by these interfaces that also needed to be implemented. The headers for these are not yet present in ArrayedBinaryTreeWithCursors280<I> - you need to add them. Until you do, the com-piler will complain on line 15 that there are unimplemented abstract methods inherited from the interfaces. The interfaces Dict280<I> and Cursor280<I> and their ancestors (yes, they have ancestor interfaces!) document what these methods are supposed to do.

You may not modify any of the existing code in the provided ArrayedBinaryTreeWithCursors280.java file, but you can add to it. You may also not modify any other files within lib280-asn2.

There is already a regression test included in ArrayedBinaryTreeWithCursors280<I>. Your completed implementation of the arrayed binary tree should pass the given regression test. If all the regression tests are successful, the only output should be: Regression test complete.

Hint: one of your first major decisions after adding the appropriate method headers for the inherited abstract methods will be to start implementing the insert method and decide where the new element

should be inserted. If you think about it, there's really only one place it can go...

Hint: The algorithm for deleting an element is to replace the element to be deleted by the right-most element in the bottom level of the tree, then delete the right-most element in the bottom level of the tree.

Reminder: the elements of the items array (defined in the abstract class ArrayedBinaryTree280<I> ) represent the nodes of the tree. You are storing the contents of nodes in the array. There is no node class. It is very important that the contents of the root are stored in offset 1 and we don't use cell 0 of the array, otherwise, the given formulae for finding the child or parent of a node at offset i will not work correctly.

Attachment:- Java.zip

Reference no: EM131563158

Questions Cloud

Describe the spread of the rumor in terms of the speed : Spread of a rumor initially, a handful of students heard a rumor on campus. The rumor spread and, after t hr, the number had grown to n(t).
Debt–equity ratio for this company based on market values : What is the debt–equity ratio for this company based on market values?
The relation between attitudes and job satisfaction : Discuss how the article's content relates to the question. How does the article answer the question? What justification does the author(s) use?
What percentage of stock is needed : What percentage of stock is needed to have one of her friends elected under the cumulative voting rule?
Determine the exact number of statements : CMPT 280- Intermediate Data Structures and Algoirthms - Determine the exact number of statements Express the function you obtained in part a) in big-Θ notation.
Discuss very briefly the nature of the control weakness : Include in your summary whether the findings of management and the auditor are similar. Discuss very briefly the nature of the control weakness
Define the process for bringing a new product : Develop a Marketing Plan.Define the types of marketing research.Define the process for bringing a new product or service to market.
Find the accruement on the company capital stock : The net investment flow (rate of capital formation) of the giant conglomerate LTF Incorporated is projected to be t square root of 1/2t^2 + 1 million.
Record the necessary entries in the journal entry : Required: Record the necessary entries in the Journal Entry Worksheet below for Trico Technologies.

Reviews

len1563158

7/13/2017 6:28:13 AM

It is an easy assignment. so please be negotiable. please read through attached file for details and instructions. attached is the pdf file which contains the questions and an attached zip file for the last question from the pdf. the elements of the items array (defined in the abstract class ArrayedBinaryTree280 represent the nodes of the tree. You are storing the contents of nodes in the array. There is no node class. It is very important that the contents of the root are stored in offset 1 and we don't use cell 0 of the array, otherwise, the given formulae for finding the child or parent of a node at offset i will not work correctly.

Write a Review

JAVA Programming Questions & Answers

  Recursive factorial program

Write a class Array that encapsulates an array and provides bounds-checked access. Create a recursive factorial program that prompts the user for an integer N and writes out a series of equations representing the calculation of N!.

  Hunt the wumpus game

Reprot on Hunt the Wumpus Game has Source Code listing, screen captures and UML design here and also, may include Javadoc source here.

  Create a gui interface

Create GUI Interface in java programing with these function: Sort by last name and print all employees info, Sort by job title and print all employees info, Sort by weekly salary and print all employees info, search by job title and print that emp..

  Plot pois on a graph

Write a JAVA program that would get the locations of all the POIs from the file and plot them on a map.

  Write a university grading system in java

University grading system maintains number of tables to store, retrieve and manipulate student marks. Write a JAVA program that would simulate a number of cars.

  Wolves and sheep: design a game

This project is designed a game in java. you choose whether you'd like to write a wolf or a sheep agent. Then, you are assigned to either a "sheep" or a "wolf" team.

  Build a graphical user interface for displaying the image

Build a graphical user interface for displaying the image groups (= cluster) in JMJRST. Design and implement using a Swing interface.

  Determine the day of the week for new year''s day

This assignment contains a java project. Project evaluates the day of the week for New Year's Day.

  Write a java windowed application

Write a Java windowed application to do online quiz on general knowledge and the application also displays the quiz result.

  Input pairs of natural numbers

Java program to input pairs of natural numbers.

  Create classes implement java interface

Interface that contains a generic type. Create two classes that implement this interface.

  Java class, array, link list , generic class

These 14 questions covers java class, Array, link list , generic class.

Free Assignment Quote

Assured A++ Grade

Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!

All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd