Download presentation
Presentation is loading. Please wait.
1
2D Array and Matrix
2
Lists’ flexibility Lists can hold ANY type of data x = [ 42, 75, 70 ] 42 75 70 list int int int x We can equally well imagine them as vertical structures. 42 list int x 75 int 70 int
3
Lists’ flexibility Lists can hold ANY type of data 42.0 75.0 70.0 42 7
double double double x 42 7 -11 list int int int x “go” “red” “sox!” list String String String x
4
2d lists or arrays Lists can hold ANY type of data -- including lists ! x = [ [1,2,3,4], [5,6], [7,8,9,10,11] ] list x
5
2d arrays Lists can hold ANY type of data -- including lists !
x = [ [1,2,3,4], [5,6], [7,8,9,10,11] ] list list x[0] x list x[1] list x[2]
6
Jagged arrays Lists can hold ANY type of data -- including lists !
x = [ [1,2,3,4], [5,6], [7,8,9,10,11] ] list list x[0] x list x[1] list x[2] Rows within 2d arrays need not be the same length
7
Rectangular arrays What does x[1] refer to?
list list x[0] x x[0][0] list x[1] list x[2] x[2][3] What does x[1] refer to? What value is changed with x[1][2]=42 ? How many rows does x have, in general ? How many columns does x have, in general ?
8
Sizing up arrays… [[0,0,0,0,0], [0,0,0,0,0], [0,0,0,0,0]]
How could we create this rectangular array of 0s? [[0,0,0,0,0], [0,0,0,0,0], [0,0,0,0,0]] x = 3*[ 5*[0] ] or x = 5*[ 3*[0] ]
9
Sizing up arrays… but NEITHER ONE works! x = 3*[ 5*[0] ] [[0,0,0,0,0],
How could we create this rectangular array of 0s? x = 3*[ 5*[0] ] but NEITHER ONE works! [[0,0,0,0,0], [0,0,0,0,0], [0,0,0,0,0]] or because lists are handled by reference ! x = 5*[ 3*[0] ]
10
What's really going on? x = 3*[ 5*[0] ] inner = 5*[0] x = 3*[inner]
"shallow copy" inner = 5*[0] copies the list reference, not the list data x = 3*[inner] list list inner x list inner list inner
11
Safely creating arrays…
def createOneRow( width ): """ does just that """ row = [] # start with nothing for col in range( width ): row = row + [0] return row # loop and append! I need to verify this. Why can't we just do return [0]*width ? I tested it and it worked, so I'm probably missing something? Anyway, this is in the script for the slides. So, how would you create a list of rows!?
12
Safely creating arrays…
def create2dArray( width, height ): """ does just that """ x = [] # start with nothing for rowCount in range( height ): row = [0] * width x = x + [row] return x Run this as well. They will need this for the lab. the same approach as before!
13
Exercise x x Before After def mystery(x): """ what happens to x ? """
Starting with the 2d array x shown here, what are the values in x after running this code? row 0 row 1 row 2 col 0 col 1 col 2 col 3 def mystery(x): """ what happens to x ? """ NUM_ROWS = len(x) NUM_COLS = len(x[0]) for row in range( 0,NUM_ROWS ): for col in range( 0,NUM_COLS ): if row == col: x[row][col] = 42 else: x[row][col] += 1 x After 42,3,4,5 6,42,8,9 10,11,42,13 What are the resulting values in x?
14
Exercise x x Before After def mystery(x): """ what happens to x ? """
Starting with the 2d array x shown here, what are the values in x after running this code? row 0 row 1 row 2 col 0 col 1 col 2 col 3 def mystery(x): """ what happens to x ? """ NUM_ROWS = len(x) NUM_COLS = len(x[0]) for row in range( 0,NUM_ROWS ): for col in range( 0,NUM_COLS ): if row == col: x[row][col] = 42 else: x[row][col] += 1 x After 42 3 4 5 6 8 9 10 11 13 42,3,4,5 6,42,8,9 10,11,42,13 What are the resulting values in x?
15
$Maximum Profit$ Your stock's prices:
A good investment strategy: maximize your profit! Day Price Stocks valid to sell , 80.0 , 80.0, 10.0 , 80.0, 10.0, 30.0 … … … … Illustrate how to solve this algorithmically. Answer should be: 42. Be sure to mention that they should not simply find min and max!!! You need to buy, and then sell AFTER you buy you must sell after you buy.
16
smallest difference >>> diff( [7,3],[0,6] ) 1
Example: smallest difference >>> diff( [7,3],[0,6] ) 1 Return the minimum difference between one value from lst1 and one value from lst2. Only consider absolute differences. def diff( lst1, lst2 ): lst1 and lst2 will be lists of numbers def diff(lst1, lst2): """ return the minimum difference between any number in lst1 and lst2 """ minSoFar = abs(lst1[0] - lst2[0]) for x in lst1: for y in lst2: if abs(x-y) < minSoFar: minSoFar = abs(x-y) return minSoFar
17
smallest difference >>> diff( [7,3],[0,6] ) 1
Example: smallest difference >>> diff( [7,3],[0,6] ) 1 Return the minimum difference between one value from lst1 and one value from lst2. Only consider absolute differences. def diff( lst1, lst2 ): lst1 and lst2 will be lists of numbers minDiffSoFar = for value1 in lst1: for value2 in lst2: diff = abs(value1 - value2) if diff < minDiffSoFar: minDiffSoFar = diff return minDiffSoFar def diff(lst1, lst2): """ return the minimum difference between any number in lst1 and lst2 """ minSoFar = abs(lst1[0] - lst2[0]) for x in lst1: for y in lst2: if abs(x-y) < minSoFar: minSoFar = abs(x-y) return minSoFar
18
HW 8, Lab -- “Life” Grid World red cells are alive Evolutionary rules
John Conway Grid World red cells are alive Evolutionary rules Everything depends on a cell’s eight neighbors Exactly 3 neighbors give birth to a new, live cell! Exactly 2 or 3 neighbors keep an existing cell alive Any other number of neighbors kill the central cell (or keep it dead) white cells are empty
19
Problem 1 -- Life Grid World red cells are alive Evolutionary rules
Everything depends on a cell’s eight neighbors Exactly 3 neighbors give birth to a new, live cell! The next several slides simulate the game. Assume this is a starting state Which cells will give birth to a new cell?" IN row,col form: 2,2 and 3,4 Exactly 2 or 3 neighbors keep an existing cell alive Any other number of neighbors kill the central cell (or keep it dead) white cells are empty
20
Problem 1 -- Life Grid World red cells are alive Evolutionary rules
Everything depends on a cell’s eight neighbors Exactly 3 neighbors give birth to a new, live cell! add (1,3) and (4,3) delete (2,3) and (3,3) Exactly 2 or 3 neighbors keep an existing cell alive Any other number of neighbors kill the central cell (or keep it dead) white cells are empty
21
Problem 1 -- Life Grid World red cells are alive Evolutionary rules
Everything depends on a cell’s eight neighbors Exactly 3 neighbors give birth to a new, live cell! Exactly 2 or 3 neighbors keep an existing cell alive Any other number of neighbors kill the central cell (or keep it dead) Keep going! white cells are empty life out there...
22
Problem 1 -- Creating Life
next_life_generation( A ) returns new generation or "array" old generation or "array" 1 2 3 4 5 1 2 3 4 5 1 1 2 2 Adds (1,1), (2,3), and (3,1) Deletes (4,4) Answer next slide 3 3 4 4 5 5
23
Problem 1 -- Creating Life
next_life_generation( A ) returns new generation or "array" old generation or "array" 1 2 3 4 5 1 2 3 4 5 1 1 2 2 3 3 4 4 5 5
24
Problem 1 -- Details For each generation… ? 0 represents an empty cell
next_life_generation( A ) returns new generation or "array" old generation or "array" For each generation… 0 represents an empty cell 1 represents a living cell outermost edge should always be left empty (even if there are 3 neighbors) compute all cells based on their previous neighbors before updating any of them ? life out there...
25
Problem 1 – to ∞ and beyond!
"rocks" Are there stable life configurations? "plants" Are there oscillating life configurations? period 3 period 2 "animals" Are there self-propagating life configurations?
26
A few matrix and array problems
Given a matrix (2D array with equal dimension), how to compute the sum for the top-right half? [[3,2,6,8], [9,2,5,7], [0,3,2,3], [1,2,3,4]] The result should be 42
27
The key is to figure out the indices
columns 1 2 3 [[3,2,6,8], [9,2,5,7], [0,3,2,3], [1,2,3,4]] rows When row is 0, column goes from 0 to 3 When row is 1, column goes from 1 to 3 When row is 2, column goes from 2 to 3 When row is 3, column goes from 3 to 3 for row in range( 4 ): for col in range( row, 4 ): # do work
28
def sumUpperRight( matrix ):
''' Sum up the upper-right corner of a matrix. Matrix is a 2D array with equal dimensions ''' sum = 0 for row in range( len( matrix ) ): # row for col in range( row, len( matrix[0] ) ): # column sum += matrix[row][col] return sum matrix = [[3,2,6,8], [9,2,5,7], [0,3,2,3], [1,2,3,4]] value = sumUpperRight( matrix ) print( 'the sum of right upper corner is ', value )
29
Given a matrix (2D array with equal dimension), how to compute the maximum for each row and each column? # compute row max for a given ‘row’ rowMax = matrix[row][0] for i in range( len( matrix[row] ) ): if matrix[row][i] > max: rowMax = matrix[row][i] But how to go through a column to compute the maximum? # compute column max for a given ‘column’ colMax = matrix[0][col] for i in range( len( matrix ) ): if matrix[i][col] > max: rowMax = matrix[i][col]
30
In addition to the row and column maximum, find the maximum of the entire matrix?
def findMax( matrix, rowMax, colMax ): ''' Given a matrix, find and return the global max, an array of row max and an array of column max ''' max = matrix[0][0] # current max for i in range( len( matrix) ): # find each row max rowMax[i] = findRowMax( matrix, i ) if rowMax[i] > max: max = rowMax[i] for i in range( len( matrix[0] ) ): # find each column max colMax[i] = findColMax( matrix, i ) if colMax[i] > max: max = colMax[i] return max
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.