Lists, Stacks, Queues Svetlin Nakov Telerik Corporation www.telerik.com.

Slides:



Advertisements
Similar presentations
Chapter 25 Lists, Stacks, Queues, and Priority Queues
Advertisements

Linked Lists in C and C++ CS-2303, C-Term Linked Lists in C and C++ CS-2303 System Programming Concepts (Slides include materials from The C Programming.
COMP171 Fall 2005 Lists.
Singly Linked Lists What is a singly-linked list? Why linked lists?
Stacks, Queues, and Linked Lists
Linked Lists.
Queues and Linked Lists
1111 Abstract Data Types Cpt S 223. School of EECS, WSU.
Data Structures ADT List
DATA STRUCTURES USING C++ Chapter 5
Chapter 24 Lists, Stacks, and Queues
Chapter 3 – Lists A list is just what the name implies, a finite, ordered sequence of items. Order indicates each item has a position. A list of size 0.
Generics, Lists, Interfaces
Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second Edition, © 2005 Pearson Education, Inc. All rights reserved Hash Tables,
Dictionaries, Hash Tables, Collisions Resolution, Sets Svetlin Nakov Telerik Corporation
Chapter 9: Data Structures I
Data Structures and Collections
Computer Science 112 Fundamentals of Programming II Overview of Collections.
Data Structures Lecture 13: QUEUES Azhar Maqsood NUST Institute of Information Technology (NIIT)
RPN and Shunting-yard algorithm Ivaylo Kenov Telerik Software Academy academy.telerik.com Technical Assistant
COSC 1P03 Data Structures and Abstraction 9.1 The Queue Whenever you are asked if you can do a job, tell 'em, "Certainly, I can!" Then get busy and find.
queues1 Queues Data structures that wait their turn.
CHAPTER 7 Queues.
Fundamentals of Python: From First Programs Through Data Structures
Queues 4/14/2017 5:24 PM 5.2 Queues Queues Dr Zeinab Eid.
COP3538 – Data Structures Using OOP Chapter 4 – Stacks and Queues.
Priority Queues. 2 Priority queue A stack is first in, last out A queue is first in, first out A priority queue is least-first-out The “smallest” element.
CS 307 Fundamentals of Computer Science 1 Abstract Data Types many slides taken from Mike Scott, UT Austin.
Unit 11 1 Unit 11: Data Structures H We explore some simple techniques for organizing and managing information H This unit focuses on: Abstract Data Types.
TCSS 342, Winter 2005 Lecture Notes
COMPSCI 125 Spring 2005 ©TheMcGraw-Hill Companies, Inc. Permission required for reproduction or display. Odds and Ends Strings (from Chapter 9) StringTokenizer.
1 Lecture 26 Abstract Data Types – IV Overview  The List ADT  Implementing Stacks as Linked List  Linked List Implementation of Queues .  Preview:
What are ADTs, STL Intro, vector, list, queue, stack Learning & Development Team Telerik Software Academy.
Lists, Stacks, Queues Svetlin Nakov Telerik Corporation
Lists, Stacks, Queues Svetlin Nakov Telerik Corporation
FEN 2012UCN Technology - Computer Science 1 Data Structures and Collections Principles revisited.NET: –Two libraries: System.Collections System.Collections.Generics.
Arrays, Lists, Stacks, Queues Static and Dynamic Implementation Svetlin Nakov Telerik Software Academy academy.telerik.com Technical Trainer
Chapter 3 List Stacks and Queues. Data Structures Data structure is a representation of data and the operations allowed on that data. Data structure is.
Data Structures and Abstract Data Types "Get your data structures correct first, and the rest of the program will write itself." - David Jones.
Liang, Introduction to Java Programming, Eighth Edition, (c) 2011 Pearson Education, Inc. All rights reserved Chapter 22 Java Collections.
Java™ How to Program, 9/e Presented by: Dr. José M. Reyes Álamo © Copyright by Pearson Education, Inc. All Rights Reserved.
Chapter 8: Data Abstractions Senem Kumova Metin. 8-2 Chapter 8: Data Abstractions 8.1 Basic Data Structures – Arrays – Lists, Stacks, Queues – Trees 8.2.
Jan 12, 2012 Introduction to Collections. 2 Collections A collection is a structured group of objects Java 1.2 introduced the Collections Framework Collections.
Chapter 9 (modified) Abstract Data Types and Algorithms Nell Dale John Lewis.
Arrays, Lists, Stacks, Queues Processing Sequences of Elements SoftUni Team Technical Trainers Software University
Stacks And Queues Chapter 18.
1 Linked-list, stack and queue. 2 Outline Abstract Data Type (ADT)‏ Linked list Stack Queue.
Standard Template Library The Standard Template Library was recently added to standard C++. –The STL contains generic template classes. –The STL permits.
Dictionaries, Hash Tables, Collisions Resolution, Sets Svetlin Nakov Telerik Corporation
Chapter 7 Queues Introduction Queue applications Implementations.
Data Structures David Kauchak cs302 Spring Data Structures What is a data structure? Way of storing data that facilitates particular operations.
1 Principles revisited.NET: Two libraries: System.Collections System.Collections.Generics Data Structures and Collections.
Arrays, Link Lists, and Recursion Chapter 3. Sorting Arrays: Insertion Sort Insertion Sort: Insertion sort is an elementary sorting algorithm that sorts.
Lists, Stacks, Queues Svetlin Nakov Telerik Software Academy Manager Technical Trainer
List Structures What is a list? A homogeneous collection of elements with a linear relationship between the elements linear relationship - each element.
Introduction to Data Structure and Algorithms
CSC 243 – Java Programming, Fall, 2008 Tuesday, September 30, end of week 5, Interfaces, Derived Classes, and Abstract Classes.
CPS120: Introduction to Computer Science Nell Dale John Lewis Abstract Data Types.
Linked Data Structures
Data Structure By Amee Trivedi.
Set Collection A Bag is a general collection class that implements the Collection interface. A Set is a collection that resembles a Bag with the provision.
Efficiency of in Binary Trees
CMSC 341 Lecture 5 Stacks, Queues
structures and their relationships." - Linus Torvalds
CS313D: Advanced Programming Language
structures and their relationships." - Linus Torvalds
Lesson 6. Types Equality and Identity. Collections.
Fundaments of Game Design
structures and their relationships." - Linus Torvalds
Presentation transcript:

Lists, Stacks, Queues Svetlin Nakov Telerik Corporation

1. Abstract Data Types (ADT) 2. Lists – The List Class Static and Linked Static and Linked 3. Stacks – The Stack Class Static and Linked Static and Linked 4. Queues – The Queue Class Circular and Linked Circular and Linked Priority Queue Priority Queue C# Implementation C# Implementation

Basic Data Structures

An Abstract Data Type (ADT) is a data type together with the operations, whose properties are specified independently of any particular implementation An Abstract Data Type (ADT) is a data type together with the operations, whose properties are specified independently of any particular implementation ADT are set of definitions of operations (like the interfaces in C#) ADT are set of definitions of operations (like the interfaces in C#) Can have several different implementations Can have several different implementations Different implementations can have different efficiency Different implementations can have different efficiency

Linear structures Linear structures Lists: fixed size and variable size Lists: fixed size and variable size Stacks: LIFO (Last In First Out) structure Stacks: LIFO (Last In First Out) structure Queues: FIFO (First In First Out) structure Queues: FIFO (First In First Out) structure Trees Trees Binary, ordered, balanced, etc. Binary, ordered, balanced, etc. Dictionaries (maps) Dictionaries (maps) Contain pairs (key, value) Contain pairs (key, value) Hash tables: use hash functions to search/insert Hash tables: use hash functions to search/insert

Static and Dynamic Implementations

Data structure (container) that contains a sequence of elements Data structure (container) that contains a sequence of elements Can have variable size Can have variable size Elements are arranged linearly, in sequence Elements are arranged linearly, in sequence Can be implemented in several ways Can be implemented in several ways Statically (using array fixed size) Statically (using array fixed size) Dynamically (linked implementation) Dynamically (linked implementation) Using resizable array (the List class) Using resizable array (the List class)

Implemented by an array Implemented by an array Provides direct access by index Provides direct access by index Has fixed capacity Has fixed capacity Insertion, deletion and resizing are slow operations Insertion, deletion and resizing are slow operations L

Dynamic (pointer-based) implementation Dynamic (pointer-based) implementation Different forms Different forms Singly-linked and doubly-linked Singly-linked and doubly-linked Sorted and unsorted Sorted and unsorted Singly-linked list Singly-linked list Each item has 2 fields: value and next Each item has 2 fields: value and next2next7next head4next5next null

Doubly-linked List Doubly-linked List Each item has 3 fields: value, next and prev Each item has 3 fields: value, next and prev2next prev head null7next prev null4next prev5next prev tail

Auto-Resizable Indexed Lists

Implements the abstract data structure list using an array Implements the abstract data structure list using an array All elements are of the same type T All elements are of the same type T T can be any type, e.g. List, List, List T can be any type, e.g. List, List, List Size is dynamically increased as needed Size is dynamically increased as needed Basic functionality: Basic functionality: Count – returns the number of elements Count – returns the number of elements Add(T) – appends given element at the end Add(T) – appends given element at the end

static void Main() { List list = new List () { "C#", "Java" }; List list = new List () { "C#", "Java" }; list.Add("SQL"); list.Add("SQL"); list.Add("Python"); list.Add("Python"); foreach (string item in list) foreach (string item in list) { Console.WriteLine(item); Console.WriteLine(item); } // Result: // Result: // C# // C# // Java // Java // SQL // SQL // Python // Python} Inline initialization: the compiler adds specified elements to the list.

Live Demo

list[index] – access element by index list[index] – access element by index Insert(index, T) – inserts given element to the list at a specified position Insert(index, T) – inserts given element to the list at a specified position Remove(T) – removes the first occurrence of given element Remove(T) – removes the first occurrence of given element RemoveAt(index) – removes the element at the specified position RemoveAt(index) – removes the element at the specified position Clear() – removes all elements Clear() – removes all elements Contains(T) – determines whether an element is part of the list Contains(T) – determines whether an element is part of the list

IndexOf() – returns the index of the first occurrence of a value in the list (zero-based) IndexOf() – returns the index of the first occurrence of a value in the list (zero-based) Reverse() – reverses the order of the elements in the list or a portion of it Reverse() – reverses the order of the elements in the list or a portion of it Sort() – sorts the elements in the list or a portion of it Sort() – sorts the elements in the list or a portion of it ToArray() – converts the elements of the list to an array ToArray() – converts the elements of the list to an array TrimExcess() – sets the capacity to the actual number of elements TrimExcess() – sets the capacity to the actual number of elements

static List FindPrimes(int start, int end) { List primesList = new List (); List primesList = new List (); for (int num = start; num <= end; num++) for (int num = start; num <= end; num++) { bool prime = true; bool prime = true; for (int div = 2; div <= Math.Sqrt(num); div++) for (int div = 2; div <= Math.Sqrt(num); div++) { if (num % div == 0) if (num % div == 0) { prime = false; prime = false; break; break; } } if (prime) if (prime) { primesList.Add(num); primesList.Add(num); } } return primesList; return primesList;}

Live Demo

int[] Union(int[] firstArr, int[] secondArr) { List union = new List (); List union = new List (); union.AddRange(firstArray); union.AddRange(firstArray); foreach (int item in secondArray) foreach (int item in secondArray) if (! union.Contains(item)) if (! union.Contains(item)) union.Add(item); union.Add(item); return union.ToArray(); return union.ToArray();} int[] Intersection(int[] firstArr, int[] secondArr) { List intersect = new List (); List intersect = new List (); foreach (int item in firstArray) foreach (int item in firstArray) if (Array.IndexOf(secondArray, item) != -1) if (Array.IndexOf(secondArray, item) != -1) intersect.Add(item); intersect.Add(item); return intersect.ToArray(); return intersect.ToArray();}

Live Demo

Static and Dynamic Implementation

LIFO (Last In First Out) structure LIFO (Last In First Out) structure Elements inserted (push) at top Elements inserted (push) at top Elements removed (pop) from top Elements removed (pop) from top Useful in many situations Useful in many situations E.g. the execution stack of the program E.g. the execution stack of the program Can be implemented in several ways Can be implemented in several ways Statically (using array) Statically (using array) Dynamically (linked implementation) Dynamically (linked implementation) Using the Stack class Using the Stack class

Static (array-based) implementation Static (array-based) implementation Has limited (fixed) capacity Has limited (fixed) capacity The current index ( top ) moves left / right with each pop / push The current index ( top ) moves left / right with each pop / push S top

Dynamic (pointer-based) implementation Dynamic (pointer-based) implementation Each item has 2 fields: value and next Each item has 2 fields: value and next Special pointer keeps the top element Special pointer keeps the top element2next7next top4next5next null

The Standard Stack Implementation in.NET

Implements the stack data structure using an array Implements the stack data structure using an array Elements are from the same type T Elements are from the same type T T can be any type, e.g. Stack T can be any type, e.g. Stack Size is dynamically increased as needed Size is dynamically increased as needed Basic functionality: Basic functionality: Push(T) – inserts elements to the stack Push(T) – inserts elements to the stack Pop() – removes and returns the top element from the stack Pop() – removes and returns the top element from the stack

Basic functionality: Basic functionality: Peek() – returns the top element of the stack without removing it Peek() – returns the top element of the stack without removing it Count – returns the number of elements Count – returns the number of elements Clear() – removes all elements Clear() – removes all elements Contains(T) – determines whether given element is in the stack Contains(T) – determines whether given element is in the stack ToArray() – converts the stack to an array ToArray() – converts the stack to an array TrimExcess() – sets the capacity to the actual number of elements TrimExcess() – sets the capacity to the actual number of elements

Using Push(), Pop() and Peek() methods Using Push(), Pop() and Peek() methods static void Main() { Stack stack = new Stack (); Stack stack = new Stack (); stack.Push("1. Ivan"); stack.Push("1. Ivan"); stack.Push("2. Nikolay"); stack.Push("2. Nikolay"); stack.Push("3. Maria"); stack.Push("3. Maria"); stack.Push("4. George"); stack.Push("4. George"); Console.WriteLine("Top = {0}", stack.Peek()); Console.WriteLine("Top = {0}", stack.Peek()); while (stack.Count > 0) while (stack.Count > 0) { string personName = stack.Pop(); string personName = stack.Pop(); Console.WriteLine(personName); Console.WriteLine(personName); }}

Live Demo

We are given an arithmetical expression with brackets that can be nested We are given an arithmetical expression with brackets that can be nested Goal: extract all sub-expressions in brackets Goal: extract all sub-expressions in brackets Example: Example: 1 + (2 - (2+3) * 4 / (3+1)) * (2 - (2+3) * 4 / (3+1)) * 5 Result: Result: (2+3) | (3+1) | (2 - (2+3) * 4 / (3+1)) (2+3) | (3+1) | (2 - (2+3) * 4 / (3+1)) Algorithm: Algorithm: For each ' ( ' push its index in a stack For each ' ( ' push its index in a stack For each ' ) ' pop the corresponding start index For each ' ) ' pop the corresponding start index

string expression = "1 + (2 - (2+3) * 4 / (3+1)) * 5"; Stack stack = new Stack (); for (int index = 0; index < expression.Length; index++) { char ch = expression[index]; char ch = expression[index]; if (ch == '(') if (ch == '(') { stack.Push(index); stack.Push(index); } else if (ch == ')') else if (ch == ')') { int startIndex = stack.Pop(); int startIndex = stack.Pop(); int length = index - startIndex + 1; int length = index - startIndex + 1; string contents = expression.Substring(startIndex, length); string contents = expression.Substring(startIndex, length); Console.WriteLine(contents); Console.WriteLine(contents); }}

Live Demo

Static and Dynamic Implementation

FIFO (First In First Out) structure FIFO (First In First Out) structure Elements inserted at the tail (Enqueue) Elements inserted at the tail (Enqueue) Elements removed from the head (Dequeue) Elements removed from the head (Dequeue) Useful in many situations Useful in many situations Print queues, message queues, etc. Print queues, message queues, etc. Can be implemented in several ways Can be implemented in several ways Statically (using array) Statically (using array) Dynamically (using pointers) Dynamically (using pointers) Using the Queue class Using the Queue class

Static (array-based) implementation Static (array-based) implementation Has limited (fixed) capacity Has limited (fixed) capacity Implement as a circular array Implement as a circular array Has head and tail indices, pointing to the head and the tail of the cyclic queue Has head and tail indices, pointing to the head and the tail of the cyclic queue S headtail

Dynamic (pointer-based) implementation Dynamic (pointer-based) implementation Each item has 2 fields: value and next Each item has 2 fields: value and next Dynamically create and delete objects Dynamically create and delete objects2next7next head4next5next null tail

Standard Queue Implementation in.NET

Implements the queue data structure using a circular resizable array Implements the queue data structure using a circular resizable array Elements are from the same type T Elements are from the same type T T can be any type, e.g. Stack T can be any type, e.g. Stack Size is dynamically increased as needed Size is dynamically increased as needed Basic functionality: Basic functionality: Enqueue(T) – adds an element to the end of the queue Enqueue(T) – adds an element to the end of the queue Dequeue() – removes and returns the element at the beginning of the queue Dequeue() – removes and returns the element at the beginning of the queue

Basic functionality: Basic functionality: Peek() – returns the element at the beginning of the queue without removing it Peek() – returns the element at the beginning of the queue without removing it Count – returns the number of elements Count – returns the number of elements Clear() – removes all elements Clear() – removes all elements Contains(T) – determines whether given element is in the queue Contains(T) – determines whether given element is in the queue ToArray() – converts the queue to an array ToArray() – converts the queue to an array TrimExcess() – sets the capacity to the actual number of elements in the queue TrimExcess() – sets the capacity to the actual number of elements in the queue

Using Enqueue() and Dequeue() methods Using Enqueue() and Dequeue() methods static void Main() { Queue queue = new Queue (); Queue queue = new Queue (); queue.Enqueue("Message One"); queue.Enqueue("Message One"); queue.Enqueue("Message Two"); queue.Enqueue("Message Two"); queue.Enqueue("Message Three"); queue.Enqueue("Message Three"); queue.Enqueue("Message Four"); queue.Enqueue("Message Four"); while (queue.Count > 0) while (queue.Count > 0) { string message = queue.Dequeue(); string message = queue.Dequeue(); Console.WriteLine(message); Console.WriteLine(message); }}

Live Demo

We are given the sequence: We are given the sequence: S = N, N+1, 2*N, N+2, 2*(N+1), 2*N+1, 4*N, … Find the first index of given number P Find the first index of given number P Example: N = 3, P = 16 Example: N = 3, P = 16 S = 3, 4, 6, 5, 8, 7, 12, 6, 10, 9, 16, 8, 14, … Index of P = *2 +1 *2 +1 *2

int n = 3, p = 16; Queue queue = new Queue (); queue.Enqueue(n); int index = 0; while (queue.Count > 0) { int current = queue.Dequeue(); int current = queue.Dequeue(); index++; index++; if (current == p) if (current == p) { Console.WriteLine("Index = {0}", index); Console.WriteLine("Index = {0}", index); return; return; } queue.Enqueue(current+1); queue.Enqueue(current+1); queue.Enqueue(2*current); queue.Enqueue(2*current);}

Live Demo

What is a Priority Queue What is a Priority Queue Data type to efficiently support finding the item with the highest priority Data type to efficiently support finding the item with the highest priority Basic operations Basic operations Enqueue(T element) Enqueue(T element) Dequeue Dequeue There is no build-in Priority Queue in.NET There is no build-in Priority Queue in.NET Can be easily implemented using PowerCollections Can be easily implemented using PowerCollections

class PriorityQueue where T:IComparable class PriorityQueue where T:IComparable { private OrderedBag bag; private OrderedBag bag; public int Count public int Count { get { return bag.Count; } get { return bag.Count; } private set{ } private set{ } } public PriorityQueue() public PriorityQueue() { bag = new OrderedBag (); bag = new OrderedBag (); } public void Enqueue(T element) public void Enqueue(T element) { bag.Add(element); bag.Add(element); } public T Dequeue() public T Dequeue() { var element = bag.GetFirst(); var element = bag.GetFirst(); bag.RemoveFirst(); bag.RemoveFirst(); return element; return element; }} 47 Necessary to provide comparable elements

The generic type is needed to implement IComparable The generic type is needed to implement IComparable It is not necessary to use OrderedBag It is not necessary to use OrderedBag Other Data Structures also can be used Other Data Structures also can be used Adding and Removing Element in the Priority Queue is with complexity logN Adding and Removing Element in the Priority Queue is with complexity logN Keeps the elements Sorted Keeps the elements Sorted Always returns the best element that fulfills some condition Always returns the best element that fulfills some condition E.g. the smallest or the biggest element E.g. the smallest or the biggest element 48

Live Demo 49

ADT are defined by list of operations independent of their implementation ADT are defined by list of operations independent of their implementation The basic linear data structures in the computer programming are: The basic linear data structures in the computer programming are: List (static, linked) List (static, linked) Implemented by the List class in.NET Implemented by the List class in.NET Stack (static, linked) Stack (static, linked) Implemented by the Stack class in.NET Implemented by the Stack class in.NET Queue (static, linked) Queue (static, linked) Implemented by the Queue class in.NET Implemented by the Queue class in.NET Priority Queue Priority Queue Implemented by the OrderedBag class Implemented by the OrderedBag class

Questions?

1. Write a program that reads from the console a sequence of positive integer numbers. The sequence ends when empty line is entered. Calculate and print the sum and average of the elements of the sequence. Keep the sequence in List. 2. Write a program that reads N integers from the console and reverses them using a stack. Use the Stack class. 3. Write a program that reads a sequence of integers ( List ) ending with an empty line and sorts them in an increasing order.

4. Write a method that finds the longest subsequence of equal numbers in given List and returns the result as new List. Write a program to test whether the method works correctly. 5. Write a program that removes from given sequence all negative numbers. 6. Write a program that removes from given sequence all numbers that occur odd number of times. Example: {4, 2, 2, 5, 2, 3, 2, 3, 1, 5, 2} {5, 3, 3, 5}

7. Write a program that finds in given array of integers (all belonging to the range [ ]) how many times each of them occurs. Example: array = {3, 4, 4, 2, 3, 3, 4, 3, 2} 2 2 times 3 4 times 4 3 times 8. * The majorant of an array of size N is a value that occurs in it at least N/2 + 1 times. Write a program to find the majorant of given array (if exists). Example: {2, 2, 3, 3, 2, 3, 4, 3, 3} 3

9. We are given the following sequence: S 1 = N; S 2 = S 1 + 1; S 3 = 2*S 1 + 1; S 4 = S 1 + 2; S 5 = S 2 + 1; S 6 = 2*S 2 + 1; S 7 = S 2 + 2;... Using the Queue class write a program to print its first 50 members for given N. Example: N=2 2, 3, 5, 4, 4, 7, 5, 6, 11, 7, 5, 9, 6,...

10. We are given numbers N and M and the following operations: a)N = N+1 b)N = N+2 c)N = N*2 Write a program that finds the shortest sequence of operations from the list above that starts from N and finishes in M. Hint: use a queue. Example: N = 5, M = 16 Example: N = 5, M = 16 Sequence: Sequence:

11. Write a class Student, that has three fields: name (String), age (Integer) and paidSemesterOnline (Boolean). When in a queue the students who paid online are with higher priority than those who are about to pay the semester. Write a program which with a given queue of student determine whose turn it is. Hint: use priority queue 57

12. Implement the data structure linked list. Define a class ListItem that has two fields: value (of type T ) and nextItem (of type ListItem ). Define additionally a class LinkedList with a single field firstElement (of type ListItem ). 13. Implement the ADT stack as auto-resizable array. Resize the capacity on demand (when no space is available to add / insert a new element). 14. Implement the ADT queue as dynamic linked list. Use generics (LinkedQueue ) to allow storing different data types in the queue.

15. * We are given a labyrinth of size N x N. Some of its cells are empty ( 0 ) and some are full ( x ). We can move from an empty cell to another empty cell if they share common wall. Given a starting position ( * ) calculate and fill in the array the minimal distance from this position to any other cell in the array. Use " u " for all unreachable cells. Example: 000x0x0x0x0x 0*x0x0 0x xx0 000x0x345xux2x6xux 1*x8x10 2x xx10 456xux