CSE373: Data Structures and Algorithms Lecture 1: Introduction; ADTs; Stacks/Queues Catie Baker Spring 2015.

Slides:



Advertisements
Similar presentations
Stacks and Queues CSC220 Data Structure Winter
Advertisements

CS 206 Introduction to Computer Science II 03 / 04 / 2009 Instructor: Michael Eckmann.
 Abstract Data Type Abstract Data Type  What is the difference? What is the difference?  Stacks Stacks  Stack operations Stack operations  Parsing.
 Balancing Symbols 3. Applications
Come up and say hello! 1. CPSC 221: Algorithms and Data Structures Lecture #0: Introduction Steve Wolfman 2009W1 2.
CSE332: Data Abstractions Lecture 1: Introduction; Stacks/Queues Dan Grossman Spring 2010.
June 13, Introduction to CS II Data Structures Hongwei Xi Comp. Sci. Dept. Boston University.
CMSC 132: Object-Oriented Programming II Nelson Padua-Perez William Pugh Department of Computer Science University of Maryland, College Park.
Administrivia- Introduction CSE 373 Data Structures.
COMP171 Data Structures and Algorithm Huamin Qu Lecture 1 (Sept. 1, 2005)
COMP171 Data Structures and Algorithm Qiang Yang Lecture 1 ( Fall 2006)
CSE 326: Data Structures Lecture #0 Introduction Steve Wolfman Winter Quarter 2000.
July 16, Introduction to CS II Data Structures Hongwei Xi Comp. Sci. Dept. Boston University.
CSE 326: Data Structures Lecture #0 Introduction Bart Niswonger Summer Quarter 2001.
CSE373: Data Structures and Algorithms Lecture 1: Introduction; ADTs; Stacks/Queues Dan Grossman Fall 2013.
CSE373: Data Structures and Algorithms Lecture 1: Introduction; ADTs; Stacks/Queues Lauren Milne Summer 2015.
CSCE 3110 Data Structures and Algorithm Analysis.
Data Structures and Programming.  John Edgar2.
Computer Science 102 Data Structures and Algorithms V Fall 2009 Lecture 1: administrative details Professor: Evan Korth New York University 1.
CSE 373 Data Structures and Algorithms Lecture 2: Queues.
WEEK 1 CS 361: ADVANCED DATA STRUCTURES AND ALGORITHMS Dong Si Dept. of Computer Science 1.
© 2004 Goodrich, Tamassia CS2210 Data Structures and Algorithms Lecture 1: Course Overview Instructor: Olga Veksler.
Data Structures and Programming.  Today:  Administrivia  Introduction to 225, Stacks  Course website: 
CSE 501N Fall ‘09 00: Introduction 27 August 2009 Nick Leidenfrost.
CSE332: Data Abstractions Lecture 1: Introduction; Stacks/Queues Tyler Robison Summer 2010.
CSE332: Data Abstractions Lecture 26: Course Victory Lap Dan Grossman Spring 2012.
CSCA48 Course Summary.
CSE373: Data Structures and Algorithms Lecture 1: Introduction; ADTs; Stacks/Queues Nicki Dell Spring 2014.
CSE 332 Data Abstractions: Introduction and ADTs Kate Deibel Summer 2012 June 18, 2012CSE 332 Data Abstractions, Summer
CSE332: Data Abstractions Lecture 1: Introduction; ADTs; Stacks/Queues Dan Grossman Spring 2012.
Introduction to Data Structures
Computer Science 102 Data Structures and Algorithms CSCI-UA.0102 Fall 2012 Lecture 1: administrative details Professor: Evan Korth New York University.
Nirmalya Roy School of Electrical Engineering and Computer Science Washington State University Cpt S 223 – Advanced Data Structures Course Introduction.
Come up and say hello! 1. CPSC 221: Algorithms and Data Structures Lecture #0: Introduction Steve Wolfman 2010W2 2.
CSE373: Data Structures and Algorithms Lecture 1: Introduction; ADTs; Stacks/Queues Kevin Quinn Fall 2015.
Foundation of Computing Systems Lecture 3 Stacks and Queues.
Stacks And Queues Chapter 18.
ICS202 Data Structures King Fahd University of Petroleum & Minerals College of Computer Science & Engineering Information & Computer Science Department.
Nirmalya Roy School of Electrical Engineering and Computer Science Washington State University Cpt S 223 – Advanced Data Structures Course Introduction.
90-723: Data Structures and Algorithms for Information Processing Copyright © 1999, Carnegie Mellon. All Rights Reserved. 1 Lecture 1: Introduction Data.
CSE373: Data Structures and Algorithms Lecture 1: Introduction; ADTs; Stacks/Queues Linda Shapiro Winter 2015.
CSC 212 Sequences & Iterators. Announcements Midterm in one week  Will cover through chapter 5 of book  Midterm will be open book, open note (but, closed.
CMSC 2021 CMSC 202 Computer Science II for Majors Spring 2002 Sections Ms. Susan Mitchell.
1 Data Structures COP 4530 Spring 2010 MW 4:35 PM – 5:50 PM CHE 101 Instructor:Dr. Rollins Turner Dept. of Computer Science and Engineering ENB
CSE 373: Data Structures and Algorithms Lecture 2: Queues.
Winter 2016CISC101 - Prof. McLeod1 CISC101 Elements of Computing Science I Course Web Site: The lecture outlines.
Course Info Instructor U.T. Nguyen Office: CSEB Office hours: Tuesday, 14:30-15:30 Thursday, 12:00-12:45 By.
Data Structures and Algorithms in Java AlaaEddin 2012.
3/3/20161 Stacks and Queues Introduction to Data Structures Ananda Gunawardena.
Principles of Imperative Computation Lecture 1 January 15 th, 2012.
CSE373: Data Structures and Algorithms Lecture 1: Introduction; ADTs; Stacks/Queues Aaron Bauer Winter 2014.
CSE373: Data Structures and Algorithms Lecture 1: Introduction; ADTs; Stacks/Queues Linda Shapiro Spring 2016.
COMP9024: Data Structures and Algorithms Course Outline Hui Wu Session 1, 2016
CSE373: Data Structures and Algorithms Lecture 1: Introduction; ADTs; Stacks/Queues Hunter Zahn Summer 2016 CSE373: Data Structures and Algorithms1.
COMP9024: Data Structures and Algorithms
CSE373: Data Structures and Algorithms
March 27 – Course introductions; Adts; Stacks and Queues
CSE 373: Data Structures and Algorithms
Computer Science 102 Data Structures CSCI-UA
September 27 – Course introductions; Adts; Stacks and Queues
Lecture 1: Welcome to CSE 373
structures and their relationships." - Linus Torvalds
Introduction CSE 373 Data Structures.
Introduction to CS II Data Structures
Ben Lerner Summer Quarter 2007 Lecture 1
Cs212: Data Structures Computer Science Department Lecture 7: Queues.
Spring 2016 Richard Anderson Lecture 1
Administrivia- Introduction
Administrivia- Introduction
structures and their relationships." - Linus Torvalds
Presentation transcript:

CSE373: Data Structures and Algorithms Lecture 1: Introduction; ADTs; Stacks/Queues Catie Baker Spring 2015

Registration We have 150 students registered and many on the wait list! If you’re thinking of dropping the course please decide soon! Wait listed students Please sign up on the paper waiting list after class, so I know who you are. If you think you absolutely have to take the course this quarter, speak to the CSE undergraduate advisors. The CSE advisors and I will decide by end of Friday who gets in. 2CSE 373: Data Structures & AlgorithmsSpring 2015

Welcome! We have 10 weeks to learn fundamental data structures and algorithms for organizing and processing information –“Classic” data structures / algorithms –How to rigorously analyze their efficiency –How to decide when to use them –Queues, dictionaries, graphs, sorting, etc. Today in class: Introductions and course mechanics What this course is about Start abstract data types (ADTs), stacks, and queues –Largely review 3CSE 373: Data Structures & AlgorithmsSpring 2015

To-do list In next hours: Read the web page Read all course policies Read Chapters 3.1 (lists), 3.6 (stacks) and 3.7 (queues) of the Weiss book –Relevant to Homework 1, due next week Set up your Java environment for Homework 1 4CSE 373: Data Structures & AlgorithmsSpring 2015

Course staff 5CSE 373: Data Structures & Algorithms Office hours, , etc. on course web-page Catie Baker 3 rd Year CSE Ph.D. Grad Student Works with Richard Ladner in Accessibility Andy Li Cyndi Ai Spring 2015

Communication Course list: –Students and staff already subscribed –You must get announcements sent there –Fairly low traffic Course staff: Discussion board –For appropriate discussions; TAs will monitor –Encouraged, but won’t use for important announcements Anonymous feedback link –For good and bad, but please be gentle. 6CSE 373: Data Structures & AlgorithmsSpring 2015

Course meetings Lecture –Materials posted, but take notes –Ask questions, focus on key ideas (rarely coding details) Optional help sessions –Help on programming/tool background –Helpful math review and example problems –Again, optional but helpful –May cancel some later in course (experimental) Office hours –Use them: please visit me for talking about course concepts or just CSE in general. 7CSE 373: Data Structures & AlgorithmsSpring 2015

Course materials All lecture will be posted –But they are visual aids, not always a complete description! –If you have to miss, find out what you missed Textbook: Weiss 3 rd Edition in Java A good Java reference of your choosing –Don’t struggle Googling for features you don’t understand 8CSE 373: Data Structures & AlgorithmsSpring 2015

Computer Lab College of Arts & Sciences Instructional Computing Lab – –Or your own machine Will use Java for the programming assignments Eclipse is recommended programming environment 9CSE 373: Data Structures & AlgorithmsSpring 2015

Course Work 6 homeworks (60%) –Most involve programming, but also written questions –Higher-level concepts than “just code it up” –First programming assignment due next week Midterm: May 6, in class (15%) Final exam: Tuesday June 9, 2:30-4:20PM (25%) 10CSE 373: Data Structures & AlgorithmsSpring 2015

Collaboration and Academic Integrity Read the course policy very carefully –Explains quite clearly how you can and cannot get/provide help on homework and projects Always explain any unconventional action on your part –When it happens, when you submit, not when asked The CSE Department and I take academic integrity extremely seriously. 11CSE 373: Data Structures & AlgorithmsSpring 2015

Some details You are expected to do your own work –Exceptions (group work), if any, will be clearly announced Sharing solutions, doing work for, or accepting work from others is cheating Referring to solutions from this or other courses from previous quarters is cheating But you can learn from each other: see the policy 12CSE 373: Data Structures & AlgorithmsSpring 2015

What this course will cover Introduction to Algorithm Analysis Lists, Stacks, Queues Trees, Hashing, Dictionaries Heaps, Priority Queues Sorting Disjoint Sets Graph Algorithms Introduction to Parallelism and Concurrency 13CSE 373: Data Structures & AlgorithmsSpring 2015

Goals Be able to make good design choices as a developer, project manager, etc. –Reason in terms of the general abstractions that come up in all non-trivial software (and many non-software) systems Be able to justify and communicate your design decisions You will learn the key abstractions used almost every day in just about anything related to computing and software. This is not a course about Java! We use Java as a tool, but the data structures you learn about can be implemented in any language. 14CSE 373: Data Structures & AlgorithmsSpring 2015

Data structures A data structure is a (often non-obvious) way to organize information to enable efficient computation over that information A data structure supports certain operations, each with a: –Meaning: what does the operation do/return –Performance: how efficient is the operation Examples: –List with operations insert and delete –Stack with operations push and pop 15CSE 373: Data Structures & AlgorithmsSpring 2015

Trade-offs A data structure strives to provide many useful, efficient operations But there are unavoidable trade-offs: –Time vs. space –One operation more efficient if another less efficient –Generality vs. simplicity vs. performance We ask ourselves questions like: –Does this support the operations I need efficiently? –Will it be easy to use (and reuse), implement, and debug? –What assumptions am I making about how my software will be used? (E.g., more lookups or more inserts?) 16CSE 373: Data Structures & AlgorithmsSpring 2015

Terminology Abstract Data Type (ADT) –Mathematical description of a “thing” with set of operations –Not concerned with implementation details Algorithm –A high level, language-independent description of a step-by- step process Data structure –A specific organization of data and family of algorithms for implementing an ADT Implementation of a data structure –A specific implementation in a specific language 17CSE 373: Data Structures & AlgorithmsSpring 2015

Example: Stacks The Stack ADT supports operations: –isEmpty : have there been same number of pops as pushes –push : adds an item to the top of the stack –pop : raises an error if empty, else removes and returns most-recently pushed item not yet returned by a pop –What else? A Stack data structure could use a linked-list or an array and associated algorithms for the operations One implementation is in the library java.util.Stack 18CSE 373: Data Structures & AlgorithmsSpring 2015

Why useful The Stack ADT is a useful abstraction because: It arises all the time in programming (e.g., see Weiss 3.6.3) –Recursive function calls –Balancing symbols in programming (parentheses) –Evaluating postfix notation: * –Clever: Infix ((3+4) * 5) to postfix conversion (see text) We can code up a reusable library We can communicate in high-level terms –“Use a stack and push numbers, popping for operators…” –Rather than, “create an array and keep indices to the…” 19CSE 373: Data Structures & AlgorithmsSpring 2015

Stack Implementations stack as a linked list stack as an array 20CSE 373: Data Structures & AlgorithmsSpring 2015 top NULL top

Stack Implementations stack as a linked list stack as an array 21CSE 373: Data Structures & AlgorithmsSpring 2015 top a a

Stack Implementations stack as a linked list stack as an array 22CSE 373: Data Structures & AlgorithmsSpring 2015 top b a ba

The Queue ADT Operations create destroy enqueue dequeue is_empty What else? Just like a stack except: –Stack: LIFO (last-in-first-out) –Queue: FIFO (first-in-first-out) 23CSE 373: Data Structures & Algorithms F E D C B enqueue dequeue G A BackFront Spring 2015

Circular Array Queue Data Structure 24CSE 373: Data Structures & Algorithms // Basic idea only! enqueue(x) { next = (back + 1) % size Q[next] = x; back = next } // Basic idea only! dequeue() { x = Q[front]; front = (front + 1) % size; return x; } bcdef Q: 0size - 1 front back What if queue is empty? –Enqueue? –Dequeue? What if array is full? How to test for empty? What is the complexity of the operations? Can you find the k th element in the queue? Spring 2015

Circular Array Example (text p 94 has another one) 25CSE 373: Data Structures & Algorithms enqueue(‘g’) o1 = dequeue( ) o2 = dequeue( ) o3 = dequeue( ) o4 = dequeue( ) o5 = dequeue( ) o6 = dequeue( ) Spring 2015

In Class Practice Spring CSE 373: Data Structures & Algorithms enqueue(‘a’) enqueue(‘b’) enqueue(‘c’) o = dequeue() enqueue(‘d’) enqueue(‘e’) enqueue(‘f’) enqueue(‘g’) enqueue(‘h’) enqueue(‘i’) f b

Winter 2015CSE 373: Data Structures & Algorithms27 b enqueue(‘a’) enqueue(‘b’) enqueue(‘c’) o = dequeue() f f f f f a a b a b c b c b b b b

Winter 2015CSE 373: Data Structures & Algorithms28 o = dequeue enqueue(‘d’) enqueue(‘e’) enqueue(‘f’) enqueue(‘g’), enqueue(‘h’) enqueue(‘i’) f f f f f b c c d c d e c d e f g h c d e f b b b b

Linked List Queue Data Structure 29CSE 373: Data Structures & Algorithms bcdef frontback // Basic idea only! enqueue(x) { back.next = new Node(x); back = back.next; } // Basic idea only! dequeue() { x = front.item; front = front.next; return x; } What if queue is empty? –Enqueue? –Dequeue? Can list be full? How to test for empty? What is the complexity of the operations? Can you find the k th element in the queue? Spring 2015

Circular Array vs. Linked List Array: –May waste unneeded space or run out of space –Space per element excellent –Operations very simple / fast –Constant-time access to k th element –For operation insertAtPosition, must shift all later elements –Not in Queue ADT List: –Always just enough space –But more space per element –Operations very simple / fast –No constant-time access to k th element –For operation insertAtPosition must traverse all earlier elements –Not in Queue ADT 30CSE 373: Data Structures & Algorithms This is stuff you should know after being awakened in the dark Spring 2015

Conclusion Abstract data structures allow us to define a new data type and its operations. Each abstraction will have one or more implementations. Which implementation to use depends on the application, the expected operations, the memory and time requirements. Both stacks and queues have array and linked implementations. We’ll look at other ordered-queue implementations later. 31CSE 373: Data Structures & AlgorithmsSpring 2015