Compare commits
2 Commits
980acef762
...
b3809fabc7
Author | SHA1 | Date | |
---|---|---|---|
b3809fabc7 | |||
48cf7ade00 |
40
2015/day5/part2.py
Normal file
40
2015/day5/part2.py
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
#!/bin/python3
|
||||||
|
|
||||||
|
import sys
|
||||||
|
from pprint import pprint
|
||||||
|
|
||||||
|
input_f = sys.argv[1]
|
||||||
|
|
||||||
|
result = 0
|
||||||
|
|
||||||
|
with open(input_f) as file:
|
||||||
|
for line in file:
|
||||||
|
tmp = line.rstrip()
|
||||||
|
print(tmp)
|
||||||
|
vowel_count = 0
|
||||||
|
t = ['ab','cd','pq','xy']
|
||||||
|
first = False
|
||||||
|
second = False
|
||||||
|
for i in t:
|
||||||
|
if tmp.find(i) != -1:
|
||||||
|
print(" is naughty because it contains " + i)
|
||||||
|
first = True
|
||||||
|
break
|
||||||
|
f = 'aeiou'
|
||||||
|
for idx,i in enumerate(tmp):
|
||||||
|
if idx+1 < len(tmp) and first == False:
|
||||||
|
#print(idx,idx+1,len(tmp))
|
||||||
|
if i == tmp[idx+1]:
|
||||||
|
second = True
|
||||||
|
if second == False and first == False:
|
||||||
|
print("naughte cus no double")
|
||||||
|
for idx,i in enumerate(tmp):
|
||||||
|
if f.find(i) != -1 and second == True and first == False:
|
||||||
|
vowel_count += 1
|
||||||
|
if vowel_count == 3:
|
||||||
|
print(" is nice because it contains " + str(vowel_count) + " vowels and double letters")
|
||||||
|
result += 1
|
||||||
|
if second == True and vowel_count < 3:
|
||||||
|
print("naughty cus " + str(vowel_count) + " vowels")
|
||||||
|
print()
|
||||||
|
print(result)
|
49
2015/day6/part1.py
Normal file
49
2015/day6/part1.py
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
import sys
|
||||||
|
from pprint import pprint
|
||||||
|
import re
|
||||||
|
from itertools import product
|
||||||
|
from collections import defaultdict
|
||||||
|
|
||||||
|
instructions = []
|
||||||
|
|
||||||
|
with open(sys.argv[1]) as file:
|
||||||
|
tmp = []
|
||||||
|
for line in file:
|
||||||
|
tmp = [re.match(r'.+?(?=\d)',line).group().strip()]
|
||||||
|
tmp += [int(i) for i in re.findall(r'\d+',line)]
|
||||||
|
instructions.append(tmp)
|
||||||
|
|
||||||
|
size = 1000
|
||||||
|
|
||||||
|
maps = defaultdict(bool)
|
||||||
|
#maps = [ [False]*size for i in range(size)]
|
||||||
|
|
||||||
|
|
||||||
|
for i in instructions:
|
||||||
|
for x in product(range(i[1],i[3]+1),range(i[2],i[4]+1)):
|
||||||
|
if i[0] == 'turn off':
|
||||||
|
maps[x] = False
|
||||||
|
elif i[0] == 'turn on':
|
||||||
|
maps[x] = True
|
||||||
|
else:
|
||||||
|
if maps[x] == True:
|
||||||
|
maps[x] = False
|
||||||
|
else:
|
||||||
|
maps[x] = True
|
||||||
|
|
||||||
|
#for y in range(i[1],i[3]+1):
|
||||||
|
# for x in range(i[2],i[4]+1):
|
||||||
|
# if i[0] == 'turn off':
|
||||||
|
# maps[x][y] = False
|
||||||
|
# elif i[0] == 'turn on':
|
||||||
|
# maps[x][y] = False
|
||||||
|
# else:
|
||||||
|
# maps[x][y] = True if maps[x][y] == False else maps[x][y] == True
|
||||||
|
|
||||||
|
count = 0
|
||||||
|
|
||||||
|
for i in product(range(0,size),range(0,size)):
|
||||||
|
if maps[i] == True:
|
||||||
|
count += 1
|
||||||
|
|
||||||
|
print(count)
|
35
2015/day6/part2.py
Normal file
35
2015/day6/part2.py
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
import sys
|
||||||
|
from pprint import pprint
|
||||||
|
import re
|
||||||
|
from itertools import product
|
||||||
|
from collections import defaultdict
|
||||||
|
|
||||||
|
instructions = []
|
||||||
|
|
||||||
|
with open(sys.argv[1]) as file:
|
||||||
|
tmp = []
|
||||||
|
for line in file:
|
||||||
|
tmp = [re.match(r'.+?(?=\d)',line).group().strip()]
|
||||||
|
tmp += [int(i) for i in re.findall(r'\d+',line)]
|
||||||
|
instructions.append(tmp)
|
||||||
|
|
||||||
|
size = 1000
|
||||||
|
|
||||||
|
maps = defaultdict(int)
|
||||||
|
|
||||||
|
for i in instructions:
|
||||||
|
for x in product(range(i[1],i[3]+1),range(i[2],i[4]+1)):
|
||||||
|
if i[0] == 'turn off':
|
||||||
|
if maps[x] != 0:
|
||||||
|
maps[x] -= 1
|
||||||
|
elif i[0] == 'turn on':
|
||||||
|
maps[x] += 1
|
||||||
|
else:
|
||||||
|
maps[x] += 2
|
||||||
|
|
||||||
|
count = 0
|
||||||
|
|
||||||
|
for i in product(range(0,size),range(0,size)):
|
||||||
|
count += maps[i]
|
||||||
|
|
||||||
|
print(count)
|
Loading…
Reference in New Issue
Block a user