Presentation is loading. Please wait.

Presentation is loading. Please wait.

1 Section 10.3 Abstract Data Types as Algebras An abstract data type (ADT) is an algebra in which the carriers (i.e., the data sets) and the operations.

Similar presentations


Presentation on theme: "1 Section 10.3 Abstract Data Types as Algebras An abstract data type (ADT) is an algebra in which the carriers (i.e., the data sets) and the operations."— Presentation transcript:

1 1 Section 10.3 Abstract Data Types as Algebras An abstract data type (ADT) is an algebra in which the carriers (i.e., the data sets) and the operations can be programmed. We’ll look at some basic abstract data types. Propositional Logic:  Bool; true, false, not, and  Example. The logical or operation can be defined as follows: or(x, y) = not(not(x) and not(y)). Quiz (1 minute). Define the logical implies operation. Answer. implies(x, y) = not(x) or y. Natural Numbers:  N, Bool; 0, iszero, succ, pred  Bool = {true, false} not : Bool  Bool and : Bool  Bool  Bool Axioms:not(true) = false not(false) = true and(x, y) = true iff x = y = true. Notice that the two constuctors 0 and succ construct the infinite set N = {0, succ(0), succ(succ(0)), …, succ n (0), ….}. The axioms imply the elements of N are distinct. e.g., succ(x) ≠ 0. For if succ(x) = 0, then apply iszero to both sides to get the contradiction false = true. So succ(x) ≠ 0. Axioms:iszero(0) = true iszero(succ(x)) = false pred(0) = 0 pred(succ(x)) = x 0  N iszero : N  Bool succ : N  N pred : N  N

2 2 Quiz (1 minute). The nonzero elements of N are distinct because succ is an injection. i.e., succ(x) = succ(y) implies x = y. Prove that succ is an injection. Proof: If succ(x) = succ(y), then apply pred to get x = pred(succ(x)) = pred(succ(y)) = y. Many useful operations can be defined with the algebra: e.g., plus, times, less, etc. Example. Let equal : N  N  Bool be a test for equality. We can define equal as follows: equal(0, 0) = true equal(0, succ(x)) = false equal(succ(x), 0) = false equal(succ(x), succ(y)) = equal(x, y). Quiz (1 minute). Define equal using if-then-else. Solution: equal(x, y) = if iszero(x) and iszero(y) then true else if iszero(x) or iszero(y) then false else equal(pred(x), pred(y)). Example/Quiz. Let gte(x, y) mean x is greater than or equal to y. Define gte. Solution.gte(x, 0) = true gte(0, succ(x)) = false gte(succ(x), succ(y)) = gte(x, y). Alternatively, gte(x, y) =if izero(y) then true else if izero(x) then false else gte(pred(x), pred(y)).

3 3 Many useful operations can be defined with the algebra: e.g., length, member, etc. Example. Let last : lists(A)  A return the rightmost element of a nonempty list. We can define last as follows: last(x) = if isempty(x) then error else if isempty(tail(x)) then head(x) else last(tail(x)). Quiz (1 minute). Write the definition for last in equational form. Answer. last(cons(x,   ) = x last(cons(x, y) = last(y). Example. Let cat : lists(A)  lists(A)  lists(A) concatenate two lists. We can define cat as follows: cat(  , x) = x cat(cons(h, t), x) = cons(h, cat(t, x)). Quiz (1 minute). Write the definition for cat in if-then-else form. Solution:cat(x, y) =if isempty(x) then y else cons(head(x), cat(tail(x),y)). Lists:  A, lists(A), Bool;  , isempty, cons, head, tail , where A represents any set.    lists(A) isempty : lists(A)  Bool cons : A  lists(A)  lists(A) head : lists(A)  A tail : lists(A)  lists(A) Axioms: isempty(   ) = true isempty(cons(h, t)) = false head(cons(h, t)) = h tail(cons(h, t)) = t

4 4 Example. Let putlast : A  lists(A)  lists(A) place an element at the right end of a list. We can define putlast as follows: putlast(x,   ) = cons(x,   ) putlast(x, cons(h, t)) = cons(h, putlast(x, t)). Quiz (1 minute). Write the definition for putlast in if-then-else form. Solution:putlast(x, y) =if isempty(y) cons(x,   ) else cons(head(y), putlast(x, tail(y))). Strings, Stacks, and Queues ADT for strings is like that for lists. ADT for stacks can defined in terms of lists by letting stacks(A) = lists(A) emptyS =   isemptyS = isempty push = cons pop = tail top = head. ADT for queues can defined in terms of lists by letting queues(A) = lists(A) emptyQ =   isemptyQ = isempty addqueue = putlast frontqueue = head deletequeue = tail.

5 5 Example. Let leaves: B(A)  N return the number of leaves in a binary tree. We can define leaves as follows, assuming we have the ADT for natural numbers. leaves(emptyT) = 0 leaves(tree(emptyT, x, emptyT)) = 1 leaves(tree(L, x, R)) = leaves(L) + leaves(R). Quiz (1 minute). Write an if-then-else definition for leaves. Solution. leaves(T) =if isempty(T) then 0 else if isempty(left(T)) and isempty(right(T)) then 1 else leaves(left(T)) + leaves(right(T)). Example/Quiz. Let pre : B(A)  lists(A) return the list of nodes from a preorder traversal of a binary tree. Solution.pre(emptyT) =   pre(tree(L, x, R)) = cons(x, cat(pre(L), pre(R))). Quiz (1 minute). Write the if-then-else form of pre. Answer. pre(T) =if isemptyT(T) then   else cons(root(T), cat(pre(left(T)), pre(right(T)))). Binary Trees:  A, B(A), Bool; emptyT, isemptyT, tree, root, left, right  Axioms: isemptyT(emptyT) = true isempty(tree(L, x, R)) = false root(tree(L, x, R)) = x left(tree(L, x, R)) = L right(tree(L, x, R)) = R emptyT  B(A) isemptyT : B(A)  Bool tree : B(A)  A  B(A)  B(A) root : B(A)  A left : B(A)  B(A) right : B(A)  B(A)

6 6 Quiz (1 minute). Let inord : B(A)  lists(A) return the list of nodes from an inorder traversal of a binary tree. Solution.inord(emptyT) =   inord(tree(L, x, R)) = cat(inord(L), cons(x, inord(R))). An if-then-else form: inord(T) =if isemptyT(T) then   else cat(inord(left(T), cons(root(T), inord(right(T))). Priority Queues:  A, P(A), Bool; emptyP, isemptyP, insert, better, best, delbest  emptyP  P(A) isemptyP : P(A)  Bool insert : A  P(A)  P(A)better : A  A  Bool best : P(A)  Adelbest : P(A)  P(A). Main Axioms: best(insert(a, p)) =if isemptyP(p) or better(a, best(p)) then a else best(p). delebest(insert(a, p)) =if isemptyP(p) or better(a, best(p)) then p else insert(a, delebest(p)). Example/Quiz. Let ƒ : P(A)  lists(A) be the function where ƒ(p) is the list of elements from p with the best element at the head of the list. Find a definition for ƒ. Solution. ƒ(p) = if isemptyP(p) then   else cons(best(p), ƒ(delebest(p))). Quiz (1 minute). How can we implement a stack with a priority queue? Answer. Let push = insert, pop = delbest, top = best, and better = true.


Download ppt "1 Section 10.3 Abstract Data Types as Algebras An abstract data type (ADT) is an algebra in which the carriers (i.e., the data sets) and the operations."

Similar presentations


Ads by Google