Add InterviewCake.com examples
Adds some of the code I generated while studying for a role transfer at Google using the fantastic resource, InterviewCake.com. This work predates the mono-repo. I should think of ways to DRY up this code and the code in crack_the_coding_interview, but I'm afraid I'm creating unnecessary work for myself that way.
This commit is contained in:
		
							parent
							
								
									b4ee283b23
								
							
						
					
					
						commit
						d4d8397e5f
					
				
					 52 changed files with 3737 additions and 0 deletions
				
			
		
							
								
								
									
										35
									
								
								data_structures_and_algorithms/inflight-entertainment.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								data_structures_and_algorithms/inflight-entertainment.py
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,35 @@
 | 
			
		|||
# possible :: Int -> [Int] -> Bool
 | 
			
		||||
def possible(flight_duration, film_durations):
 | 
			
		||||
    seeking = set()
 | 
			
		||||
 | 
			
		||||
    for x in film_durations:
 | 
			
		||||
        if x in seeking:
 | 
			
		||||
            return True
 | 
			
		||||
        else:
 | 
			
		||||
            seeking.add(flight_duration - x)
 | 
			
		||||
 | 
			
		||||
    return False
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
should = [
 | 
			
		||||
    (10, [1, 9, 8, 8, 8]),
 | 
			
		||||
    (10, [1, 9]),
 | 
			
		||||
    (10, [1, 9, 5, 5, 6]),
 | 
			
		||||
    (1, [0.5, 0.5]),
 | 
			
		||||
    (1, [0.5, 0.5]),
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
for a, b in should:
 | 
			
		||||
    print("Testing: %s %s" % (a, b))
 | 
			
		||||
    assert possible(a, b)
 | 
			
		||||
 | 
			
		||||
shouldnt = [
 | 
			
		||||
    (10, [1, 10, 1, 2, 1, 12]),
 | 
			
		||||
    (1, [0.25, 0.25, 0.25, 0.25]),
 | 
			
		||||
    (5, [1, 2, 2]),
 | 
			
		||||
]
 | 
			
		||||
for a, b in shouldnt:
 | 
			
		||||
    print("Testing: %s %s" % (a, b))
 | 
			
		||||
    assert not possible(a, b)
 | 
			
		||||
 | 
			
		||||
print("Tests pass")
 | 
			
		||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue