git-subtree-dir: users/wpcarro git-subtree-mainline:464bbcb15cgit-subtree-split:24f5a642afChange-Id: I6105b3762b79126b3488359c95978cadb3efa789
		
			
				
	
	
		
			100 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from math import floor
 | 
						|
 | 
						|
# Lists
 | 
						|
def cycle_backwards(times, xs):
 | 
						|
    n = len(xs)
 | 
						|
    for i in range(n * times):
 | 
						|
        print(xs[n - 1 - i % n])
 | 
						|
 | 
						|
def cycle_forwards(times, xs):
 | 
						|
    n = len(xs)
 | 
						|
    for i in range(n * times):
 | 
						|
        print(xs[i % n])
 | 
						|
 | 
						|
def backwards(xs):
 | 
						|
    n = len(xs)
 | 
						|
    for i in range(n):
 | 
						|
        print(xs[n - 1 - i])
 | 
						|
 | 
						|
def forwards(xs):
 | 
						|
    for i in range(len(xs)):
 | 
						|
        print(xs[i])
 | 
						|
 | 
						|
xs = [2, 5, 6, 9, 12]
 | 
						|
 | 
						|
print("Forwards")
 | 
						|
forwards(xs)
 | 
						|
print("Backwards")
 | 
						|
backwards(xs)
 | 
						|
print("Cycle forwards")
 | 
						|
cycle_forwards(2, xs)
 | 
						|
print("Cycle backwards")
 | 
						|
cycle_backwards(2, xs)
 | 
						|
 | 
						|
# Tables
 | 
						|
def tblr(table):
 | 
						|
    for row in range(len(table)):
 | 
						|
        for col in range(len(table[row])):
 | 
						|
            print(table[row][col])
 | 
						|
 | 
						|
def tbrl(table):
 | 
						|
    for row in range(len(table)):
 | 
						|
        n = len(table[row])
 | 
						|
        for col in range(n):
 | 
						|
            print(table[row][n - 1 - col])
 | 
						|
 | 
						|
def btlr(table):
 | 
						|
    n = len(table)
 | 
						|
    for row in range(n):
 | 
						|
        for col in range(len(table[row])):
 | 
						|
            print(table[n - 1 - row][col])
 | 
						|
 | 
						|
def btrl(table):
 | 
						|
    rows = len(table)
 | 
						|
    for row in range(rows):
 | 
						|
        cols = len(table[row])
 | 
						|
        for col in range(cols):
 | 
						|
            print(table[rows - 1 - row][cols - 1 - col])
 | 
						|
 | 
						|
def special(table):
 | 
						|
    rows = len(table)
 | 
						|
    cols = len(table[0])
 | 
						|
    for col in range(cols):
 | 
						|
        for row in range(rows):
 | 
						|
            print(table[row][col])
 | 
						|
 | 
						|
def double_bonus(table):
 | 
						|
    rows = len(table)
 | 
						|
    cols = len(table[0])
 | 
						|
    for i in range(rows):
 | 
						|
        row = i
 | 
						|
        for col in range(cols):
 | 
						|
            print(table[row][col % cols])
 | 
						|
            row = (row + 1) % rows
 | 
						|
 | 
						|
def free(table):
 | 
						|
    rows = len(table)
 | 
						|
    cols = len(table[0])
 | 
						|
    d = rows * cols
 | 
						|
    for i in range(d):
 | 
						|
        row = floor((i % d) / cols)
 | 
						|
        col = i % cols
 | 
						|
        print(table[row][col])
 | 
						|
 | 
						|
table = [[1,2,3,4],
 | 
						|
         [5,6,7,8]]
 | 
						|
 | 
						|
print("Top->Bottom, Left->Right")
 | 
						|
tblr(table)
 | 
						|
print("Top->Bottom, Right->Left")
 | 
						|
tbrl(table)
 | 
						|
print("Bottom->Top, Left->Right")
 | 
						|
btlr(table)
 | 
						|
print("Bottom->Top, Right->Left")
 | 
						|
btrl(table)
 | 
						|
print("Special")
 | 
						|
special(table)
 | 
						|
print("2x Bonus")
 | 
						|
double_bonus(table)
 | 
						|
print("Free")
 | 
						|
free(table)
 |