Data Structures
Data Structures
Data Structures
goals (such as adaptability) iii. implementation (of, sequence) 2) Underscore the line(s) (if any) in break the principle of en capsulation:
class Node {ublic p Object element; Node public next; { this(null, null); Node() }oid setNext(Node newText) { next = newText; v } ode getNext() { return N next; } }
3) What is the primary reason to use quadratic probing instead of linear p robing? (choose the most closely related item): i. Easier to expand the hash table when it gets fullTo avoid the primary cluster which may cause excessive data ii. collision iii. Achieve the same search time with less memory iv. Easier to support delete 4) Suppose that there are N distinct elements in a binary heap (with the max imum root). Which positions could possibly be occupied by the fourth at the largest element ? i. 1 2 or ii. 3 4 through iii. 7 2 through iv. 15 16 v. and higher 5) Characterize, using the big- Oh notation, the worst-case running time of the following algorithm: Let A b e a given array of n integers. for i <- 0 to n-1 do j <- 0 to (i*i)-1 for do A[j mod n] <Let j. end for end for Best characterization: O(_______).
2. (Linked Recall we did singly linked list in PA #4. To refresh your list) Considermemory, a list with elements (1,2,3,4,5) will be like 1 2 3 4 The list 5 Singly linked list doesnt have loops. Suppose your friend (call him Bob) has inadvertently introduced a loop into his implementation on PA #4 Consider a list with elements (1,2,3,4,5) to 1 instead of pointing to Let 3 point 4 list will be like 1 2 3 4 The 5 Since most of your friends suffer from the same bug while implementing PA#4 you decide to help them by writing functio which detects loops in a a n singly linked list. Write program that outputs false if there is no loop in the list input and true if there is a loop in a list output Fill in the following code o class list_sorted {ublic p : // You need to implement this FindLoop() bool { } private : ode* n pHead; }; struct node{ public :nt i x; node* next; };
Hin : t o Change the node data structure. Hav e some sort of counter which indicates how many times a node is visited when yo u traverse through the link list. o There might be better ideas than this! 3. (Hash You have a hash table of size m = 11 and two has functions h1 and table) h2: h1(x) = (sum of the values of the first and last letters of x) mod m ((value of the last letter) mod (m 1)) h2(x) = +1 Where the value o f a letter is its position in the alphabet, as in the following table:
a b c d m2 3 4 1 13 n o p q z 14 15 16 26
e f g h i g k l 5 6 7 8 9 10 11 12 r s t u v w x y 17 18 19 20 21 22 23 24 25
1) Draw a picture of th e resulting hash table after inserting the following words (by the order): ibex, hare, ape, bat, ko ala, mud, dog, carp, stork 2) Highlight cells that are looked at when tryin g to find bird. Do this for each of the following techniques. Chaining with h1 as your hash function. Linear probing with h1 as your hash function. 4. (Heap Give an algo rithm for changin g the value of an arbitr ary element from a ) size heap of N. Also, determine the worst case time co mplexity of your algorithm.you r algorithm in pseudo-code. You may assume that the position of Describe the element whose value to be changed is given. 5. (Binary Let T be a binary tree) T has seven nodes, what is its minimum tree. 1) If height? What is its maximum height? Draw two trees with seven nodes that achieve the minimum and maximum height, respectively . 2) When deleting a nod e of a binary search tree, if we decide to replace it withnode in its left subtree (of course, if it has one), which node should we a choose? 3) A particular binary search tree has the following known about it: A pre-order traversal yields 88, 6, 1, 3, 2, 5, 4, 30, 10, 20. A post-order traversal yields 2, 4, 5, 3, 1, 20, 10, 30, 6, 88. Draw this tree. 4) What is the in-order traversal of the tr ee from 3)? 5) Using the node values from 3), draw a minimal-height BST. Make it a co mplete tree .
class Animal {ublic p : virtual void describe() { System.out.println("Animal "); } } class Rabbit: public Animal {ublic p : Rabbit() { Animal(); } void describe() { System.out.println("Rabbit "); } void hop () { System.out.println ("Hop"); } } class Dog: public Animal {ublic p : Dog() {} void describe() { System.out.println("Dog "); } } class Poodle: public Dog {}
2) What is output of the following lines? If it is a CT / RT exception, say Assume each line is executed independently (no cascading erro so. rs).
Animal()).describe(); (new Rabbit()).describe(); (new Dog()).describe(); (new Poodle()).describe();new Animal a = Rabbit(); a.describe() ; nimal b A Rabbit(); b.hop() ; = new
7. (String This question is about the problem of searching for searching) of an M- character p attern in an N-character text string. Suppose any occurrence that student X uses the brute-force method and student Y uses the right-left scan. The students are each given the option of picking from among one of the three string
generators listed below for both programs to be tested on (both pattern and text to be generated from the same gen erato r, then both programs invoked on the same input). A. random string of As and Bs B. random ASCII charactersexcept last character is C. all As B Fill in the blanks to give the best choice and expected results from each students' point of the asymptotic number of ch aracter compares is the same, answer view. (If "1".) (a) For X's choice _______, brute-force is a factor of _______ faster than rightleft.For Y's choice _____ __, right-left is a factor o f _______ faster than brute(b) force. 8. (Operator ov Provide the declarations of the overloaded operator+ for erloading) F1 that will permit the two add operations shown in main().
class F1 {ublic p :nt i data;
};
class A1 { private :nt i a; char* name; public : A1(char* n){name=new char[strlen(n) +1]; memcpy(name, n, strlen(n) +1);} int b;}; D1 : public class A1{ public :nt i data; }; class D2 A1{}; : private
a. The public constructor for A1 allocates memory from glob al heap for the private member name therefore name can be direcly accessed b y class D2, which is derived from A1. b. Since D2 inherits A1 as a public class, both the private members of A1 are directly accessible within D2. 10. (set) Suppose se sis declared the t with Write the function belonging to
set<int> s;definition
of the the
11. (doubly linked ) (a) Why do some programmers like to have dummy nodes at eachlist of a doubly linked list? (b) What are the disadvantages of having dummy end nodes beginning of the at the list? 1 (map Suppose we want a data structure that allows us to look up a person's name 2 ) and address from his or her social security number. (a) How would you use STL map for an this? (b) How long does it take to access the name and/or addr ess from a so cial security in this data number structure?