My solutions for Advent of Code 2020
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
def split_into_list(file_path): f = open(file_path, "r") list_of_lists = [] for line in f: stripped_line = line.strip() stripped_line = str(stripped_line) line_list = stripped_line.split() list_of_lists.append(stripped_line)
f.close() return(list_of_lists)
def multiply_each_line(list_of_lists, filepath2): f = open(filepath2, "w") for i in list_of_lists: f.write(i*35) # Just an arbitrary number so I could make sure it wouldn't hit the wall #f.write("\n") f.close()
def string_to_list_of_chars(string): return [char for char in string]
def find_trees_and_opens(list_of_chars): newlist = [] for i in list_of_chars: if i == "#": newlist.append("Tree") elif i == ".": newlist.append("Open") else: print("An error occured. Sorry.") quit() return newlist
def three_right_one_down(list_of_trees_opens): newlist = [] j = 0 k = 0 for i in list_of_trees_opens: try: newlist.append(list_of_trees_opens[k]) k = k+1085 k = k+3 except: return newlist
list_of_lists = split_into_list("day3input.txt")multiply_each_line(list_of_lists, "day3inputmultiplied.txt")list_of_lists = split_into_list("day3inputmultiplied.txt")list_as_string = "".join(list_of_lists)list_of_chars = string_to_list_of_chars(list_as_string)list_of_trees_opens = find_trees_and_opens(list_of_chars)list_of_slope_encounters = three_right_one_down(list_of_trees_opens)print(list_of_slope_encounters)print(list_of_slope_encounters.count("Tree"))
|