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

  Write java statements that use a for each loop to cycle

Write java statements that use a for each loop to cycle through all the elements in an ArrayList of doubles named grades.

  Achieve these two important features

Java TM is a portable language, and being an object-oriented programming language, it also encourages component reusability. How does Java TM achieve these two important features

  Exemplify and explore some important issues of replication

You need to demonstrate the system with one server FE, three RMs and several Trams running at the same time. You will need to show service continuity in presence of failure: two RMs will be killed and the system should continue simulating the tram..

  Create a java class called samearraysexception

Create a Java class called SameArraysException that extends the Exception class.

  Write down the java code for the bank

Write down the java code for the bank of Fraud. User is presented with menu which looks something like this: 1. Deposit 2. Withdrawal 3. Check Balance 4. Exit.

  Various ways of exception handling

Various ways of exception handling

  How many states are there and draw and label the states

How many states are there and draw and label the states (with variable values) and transitions (with method names). Notice that all of the methods are total.

  Java socket hello i need to this assignment done in net

hello i need to this assignment done in net beans . and i want comment in code .also screen shots of running program

  A listener for the click events of a button

What happens if you fail to register an object as a listener for the click events of a button?

  The goal is to create a project that would let a user

the goal is to create a project that would let a user compute area and perimeter of a polygon. restrict the type of

  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.

  Determine whether a given credit card number is valid or not

Implement Luhn's algorithm in a program to determine whether a given credit card number is valid or not. You must test if the number of digits in the input is in the valid range (13 to 16), run Luhn's algorithm to test its validity.

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