Ruth Anderson University of Washington CSE 160 Spring 2018

Slides:



Advertisements
Similar presentations
Lists Ruth Anderson CSE 140 University of Washington 1.
Advertisements

Container Types in Python
String and Lists Dr. Benito Mendoza. 2 Outline What is a string String operations Traversing strings String slices What is a list Traversing a list List.
Lists Introduction to Computing Science and Programming I.
2/28/2008. >>> Overview Arrays in Python – a.k.a. Lists Ranges are Lists Strings vs. Lists Tuples vs. Lists Map-Reduce Lambda Review: Printing to a file.
CMPT 120 Lists and Strings Summer 2012 Instructor: Hassan Khosravi.
Lilian Blot CORE ELEMENTS COLLECTIONS & REPETITION Lecture 4 Autumn 2014 TPOP 1.
Python Data Types Expressions, Variables, and Assignments Strings
CS 100: Roadmap to Computing Fall 2014 Lecture 01.
Introduction to Computing Using Python Python  Python is an interactive language.  Java or C++: compile, run  Also, a main function or method  Python:
Handling Lists F. Duveau 16/12/11 Chapter 9.2. Objectives of the session: Tools: Everything will be done with the Python interpreter in the Terminal Learning.
Hossain Shahriar Announcement and reminder! Tentative date for final exam need to be fixed! Topics to be covered in this lecture(s)
Collecting Things Together - Lists 1. We’ve seen that Python can store things in memory and retrieve, using names. Sometime we want to store a bunch of.
Lists CSE 1310 – Introduction to Computers and Programming Vassilis Athitsos University of Texas at Arlington 1.
Built-in Data Structures in Python An Introduction.
Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley STARTING OUT WITH Python Python First Edition by Tony Gaddis Chapter 8 Working.
Getting Started with Python: Constructs and Pitfalls Sean Deitz Advanced Programming Seminar September 13, 2013.
10. Python - Lists The list is a most versatile datatype available in Python, which can be written as a list of comma-separated values (items) between.
Lecture 19 - More on Lists, Slicing Lists, List Functions COMPSCI 101 Principles of Programming.
Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley C H A P T E R 8 Lists and Tuples.
Lists CS303E: Elements of Computers and Programming.
1 CSC 221: Introduction to Programming Fall 2011 Lists  lists as sequences  list operations +, *, len, indexing, slicing, for-in, in  example: dice.
List comprehensions (and other shortcuts) UW CSE 160 Spring 2015.
Collections Michael Ernst CSE 190p University of Washington.
LECTURE 3 Python Basics Part 2. FUNCTIONAL PROGRAMMING TOOLS Last time, we covered function concepts in depth. We also mentioned that Python allows for.
Control flow Ruth Anderson UW CSE 160 Spring
LISTS and TUPLES. Topics Sequences Introduction to Lists List Slicing Finding Items in Lists with the in Operator List Methods and Useful Built-in Functions.
Lists Michael Ernst CSE 140 University of Washington.
Control flow Ruth Anderson UW CSE 160 Winter
Lists Ruth Anderson University of Washington CSE 160 Winter
String and Lists Dr. José M. Reyes Álamo. 2 Outline What is a string String operations Traversing strings String slices What is a list Traversing a list.
String and Lists Dr. José M. Reyes Álamo.
Generating Random Numbers
CS 100: Roadmap to Computing
Data Structures: Lists
Ruth Anderson University of Washington CSE 160 Spring 2015
List comprehensions (and other shortcuts) UW CSE 160 Winter 2016.
List comprehensions (and other shortcuts) UW CSE 160 Winter 2017.
Python Data Types Expressions, Variables, and Assignments Strings
Ruth Anderson UW CSE 160 Spring 2018
Lists Part 1 Taken from notes by Dr. Neil Moore & Dr. Debby Keen
Ruth Anderson UW CSE 160 Spring 2018
Ruth Anderson UW CSE 160 Winter 2017
Lists Part 1 Taken from notes by Dr. Neil Moore
Lists in Python.
Bryan Burlingame Halloween 2018
Arrays We often want to organize objects or primitive data in a way that makes them easy to access and change. An array is simple but powerful way to.
Chapter 10 Lists.
Data types Numeric types Sequence types float int bool list str
Ruth Anderson University of Washington CSE 160 Winter 2017
8 – Lists and tuples John R. Woodward.
Lecture 22: lists Adapted from slides by Marty Stepp and Stuart Reges
List comprehensions (and other shortcuts) UW CSE 160 Spring 2018.
4. sequence data type Rocky K. C. Chang 16 September 2018
Ruth Anderson UW CSE 140 Winter 2014
Lists A list is an ordered set of values, where each value is identified by an index. The values that make up a list are called its elements. Lists are.
String and Lists Dr. José M. Reyes Álamo.
Topics Sequences Introduction to Lists List Slicing
Lists Part 1 Taken from notes by Dr. Neil Moore
CSc 110, Spring 2018 Lecture 27: Lists that change size and File Output Adapted from slides by Marty Stepp and Stuart Reges.
CHAPTER 3: String And Numeric Data In Python
Topics Sequences Lists Copying Lists Processing Lists
CHAPTER 4: Lists, Tuples and Dictionaries
Introduction to Computer Science
Bryan Burlingame Halloween 2018
Topics Sequences Introduction to Lists List Slicing
Ruth Anderson UW CSE 160 Spring 2018
CS 100: Roadmap to Computing
Intro to Computer Science CS1510 Dr. Sarah Diesburg
Control flow: Loops UW CSE 160.
Presentation transcript:

Ruth Anderson University of Washington CSE 160 Spring 2018 Lists Ruth Anderson University of Washington CSE 160 Spring 2018

Lists What do we already know about Lists? List Operations Creation Querying Modification

Loop Examples: Where’s the list? for num in [2, 4, 6]: print num for i in [1, 2, 3]: print "Hi there!" for char in "happy": print char See in python tutor sequence is a string, NOT a list Prints the values of sequence

The range function: returns a list A typical for loop does not use an explicit list: for i in range(5): … body … range(5) produces [0, 1, 2, 3, 4] range(1,5) produces [1, 2, 3, 4] range(1,10,2) produces [1, 3, 5, 7, 9] Produces the list [0, 1, 2, 3, 4] Upper limit (exclusive) Lower limit (inclusive) step (distance between elements)

What is a list? A list is an ordered sequence of values A list of integers: [3, 1, 4, 4, 5, 9] A list of strings: ["Four", "score", "and", "seven", "years"] Each value has an index Indexing is zero-based (counting starts with zero) len([3, 1, 4, 4, 5, 9]) returns 6 1 2 3 4 5 3 1 4 5 9 1 2 3 4 “Four” “score” “and” “seven” “years”

List Operations What operations should a list support efficiently and conveniently? Creation Querying Modification

List Creation See in python tutor a = [ 3, 1, 2 * 2, 1, 10 / 2, 10 - 1 ] b = [ 5, 3, 'hi' ] c = [ 4, 'a', a ] d = [ [1, 2], [3, 4], [5, 6] ] 3 1 4 1 5 9 >>> a = [ 3, 1, 2*2, 1, 10/2, 10-1 ] >>> a [3, 1, 4, 1, 5, 9] >>> b = [ 5, 3, 'hi' ] >>> b [5, 3, 'hi'] >>> c = [4, 'a', a] >>> c [4, 'a', [3, 1, 4, 1, 5, 9]]

List Querying Expressions that return parts of lists: 1 2 3 4 5 3 1 4 5 9 Expressions that return parts of lists: Single element: mylist[index] The single element stored at that location Sublist (“slicing”): mylist[start:end] the sublist that starts at index start and ends at index end – 1 If start is omitted: defaults to 0 If end is omitted: defaults to len(mylist) mylist[:] evaluates to the whole list mylist[0:len(mylist)] also does

Indexing and Slicing Examples See in python tutor a = [3, 1, 4, 4, 5, 9] print a[0] print a[5] print a[6] print a[-1] # last element in list print a[-2] # next to last element print a[0:2] print a[0:-1] 1 2 3 4 5 3 1 4 5 9

More List Querying Find/lookup in a list x in mylist Returns True if x is found in mylist mylist.index(x) Return the integer index in the list of the first item whose value is x. It is an error if there is no such item. mylist.count(x) Return the number of times x appears in the list. 1 2 3 4 5 3 1 4 5 9

List Querying Examples See in python tutor a = [3, 1, 4, 4, 5, 9] print 5 in a print 16 in a print a.index(4) print a.index(16) print a.count(4) print a.count(16) 1 2 3 4 5 3 1 4 5 9

List Modification Insertion Removal Replacement Rearrangement

List Insertion mylist.append(x) 1 2 3 4 5 3 1 4 5 9 mylist.append(x) Extend mylist by inserting x at the end mylist.extend(L) Extend mylist by appending all the items in the argument list L to the end of mylist mylist.insert(i, x) Insert item x before position i. a.insert(0, x) inserts at the front of the list a.insert(len(a), x) is equivalent to a.append(x) You don’t have to memorize these. I’m just listing them to familiarize you with what is available, and then you can look in the documentation for details. Note: append, extend and insert all return None

List Insertion Examples See in python tutor lst = [1, 2, 3, 4] lst.append(5) lst.extend([6, 7, 8]) lst.insert(3, 3.5)

List Removal mylist.remove(x) Remove the first item from the list whose value is x It is an error if there is no such item Returns None mylist.pop([i]) Remove the item at the given position in the list, and return it. If no index is specified, a.pop() removes and returns the last item in the list. Notation from the Python Library Reference: The square brackets around the parameter, “[i]”, means the argument is optional. It does not mean you should type square brackets at that position. Note: remove returns None

List Replacement mylist[start:end] = [] mylist[len(mylist):] = L mylist[index] = newvalue mylist[start:end] = newsublist Replaces mylist[start]… mylist[end – 1] with newsublist Can change the length of the list mylist[start:end] = [] removes mylist[start]… mylist[end – 1] mylist[len(mylist):] = L is equivalent to a.extend(L)

List Removal & Replacement Examples See in python tutor List Removal & Replacement Examples lst = [1, 2, 3, 4, 5, 6, 7] print lst.pop() print lst.pop(1) lst.remove(3) lst[3] = 'blue' lst[1:3] = [10, 11, 12]

List Rearrangement list.sort() Sort the items of the list, in place. “in place” means by modifying the original list, not by creating a new list. list.reverse() Reverse the elements of the list, in place. Note: sort and reverse return None

List Modification Examples See in python tutor lst = [1, 2, 3, 4, 5] lst.append(7) lst.extend([8, 9, 3]) lst.insert(2, 2.75) lst.remove(3) print lst.pop() print lst.pop(4) lst[1:5] = [20, 21, 22] lst2 = [4, 6, 8, 2, 0] lst2.sort() lst2.reverse() lst3 = lst2 lst4 = lst2[:] lst2[-1]= 17

Exercise: list lookup Examples: Fact: mylist[index(mylist, x)] == x def index(somelist, value): """Return the position of the first occurrence of the element value in the list somelist. Return None if value does not appear in somelist.""" Examples: gettysburg = ["four", "score", "and", "seven", "years", "ago"] index(gettysburg, "and") => 2 index(gettysburg, "years") => 4 Fact: mylist[index(mylist, x)] == x

Exercise: list lookup (Answer #1) See in python tutor Exercise: list lookup (Answer #1) def index(somelist, value): """Return the position of the first occurrence of the element value in the list somelist. Return None if value does not appear in somelist.""" i = 0 for c in somelist: if c == value: return i i = i + 1 return None

Exercise: list lookup (Answer #2) See in python tutor Exercise: list lookup (Answer #2) def index(somelist, value): """Return the position of the first occurrence of the element value in the list somelist. Return None if value does not appear in somelist.""" for i in range(len(somelist)): if somelist[i] == value: return i return None

Exercise: Convert Units ctemps = [-40, 0, 20, 37, 100] # Goal: set ftemps to [-40, 32, 68, 98.6, 212] # Assume a function celsius_to_fahrenheit exists ftemps = [] Or ftemps = [celsius_to_farenehit(c) for c in ctemps]

Exercise: Convert Units (Answer) ctemps = [-40, 0, 20, 37, 100] # Goal: set ftemps to [-40, 32, 68, 98.6, 212] # Assume a function celsius_to_fahrenheit exists ftemps = [] for c in ctemps: f = celsius_to_farenheit(c) ftemps.append(f) Or ftemps = [celsius_to_farenehit(c) for c in ctemps]

More on List Slicing mylist[startindex:endindex] evaluates to a sublist of the original list mylist[index] evaluates to an element of the original list Arguments are like those to the range function mylist[start:end:step] start index is inclusive, end index is exclusive All 3 indices are optional Can assign to a slice: mylist[s:e] = yourlist

List Slicing Examples See in python tutor test_list = ['e0', 'e1', 'e2', 'e3', 'e4', 'e5', 'e6'] test_list[2:] test_list[:5] test_list[-1] test_list[-4:] test_list[:-3] test_list[:] test_list[::-1]

Answer: List Slicing Examples See in python tutor Answer: List Slicing Examples test_list = ['e0', 'e1', 'e2', 'e3', 'e4', 'e5', 'e6'] test_list[2:] From e2 to the end of the list test_list[:5] From beginning up to (but not including) e5 test_list[-1] Last element test_list[-4:] Last four elements test_list[:-3] Everything except last three elements test_list[:] Get a copy of the whole list test_list[::-1] Reverse the list

How to evaluate a list expression There are two new forms of expression: [a, b, c, d] list creation To evaluate: evaluate each element to a value, from left to right make a list of the values The elements can be arbitrary values, including lists ["a", 3, fahr_to_cent(-40), [3 + 4, 5 * 6]] a[b] list indexing or dereferencing evaluate the list expression to a value evaluate the index expression to a value if the list value is not a list, execution terminates with an error if the element is not in range (not a valid index), execution terminates with an error the value is the given element of the list value (counting from zero) Same tokens “[]” with two distinct meanings List expression Index expression

List expression examples See in python tutor List expression examples What does this mean (or is it an error)? ["four", "score", "and", "seven", "years"][2] ["four", "score", "and", "seven", "years"][0,2,3] ["four", "score", "and", "seven", "years"][[0,2,3]] ["four", "score", "and", "seven", "years"][[0,2,3][1]] >>> ["four", "score", "and", "seven", "years"][2] 'and' >>> ["four", "score", "and", "seven", "years"][0,2,3] Traceback (most recent call last): File "<pyshell#81>", line 1, in <module> ["four", "score", "and", "seven", "years"][0,2,3] TypeError: list indices must be integers, not tuple >>> ["four", "score", "and", "seven", "years"][[0,2,3]] File "<pyshell#82>", line 1, in <module> ["four", "score", "and", "seven", "years"][[0,2,3]] TypeError: list indices must be integers, not list >>> [0,2,3][1] 2 >>> ["four", "score", "and", "seven", "years"][[0,2,3][1]]