This commit is contained in:
bluepython508
2024-01-22 10:56:12 +00:00
parent d320a956f8
commit dc42625cf1
20 changed files with 293 additions and 10 deletions

View File

@@ -0,0 +1,17 @@
from hashlib import sha256
from itertools import cycle
import base64
def crypt(msg: bytes, key: str) -> bytes:
key_h = sha256()
key_h.update(key.encode('utf8'))
key = key_h.digest()
return bytes(p ^ k for (p, k) in zip(msg, cycle(key)))
def encrypt(msg: str, key: str) -> str:
return base64.b64encode(crypt(bytes(msg, 'utf8'), key)).decode('utf8')
def decrypt(msg: str, key: str) -> str:
return crypt(base64.b64decode(msg), key).decode('utf8')

View File

@@ -0,0 +1,19 @@
safe(Q1X-Q1Y, Q2X-Q2Y) :-
between(0, 7, Q1Y),
between(0, 7, Q2Y),
Q1X =\= Q2X,
Q1Y =\= Q2Y,
abs(Q1X - Q2X) =\= abs(Q1Y - Q2Y).
safe(_, []).
safe(QN, [Q | QS]) :- safe(QN, [Q | QS], 1).
safe(_, [], _).
safe(QN, [Q | QS], QX) :- safe(0-QN, QX-Q), safe(QN, QS, QX + 1).
add(Qs, QsN) :-
QsN = [Q | Qs],
safe(Q, Qs).
add(1, Qs, QsN) :- add(Qs, QsN).
add(N, Qs, QsN) :- add(Qs, QA), add(M, QA, QsN), succ(M, N).
solution(Qs) :- add(8, [], Qs).

View File

@@ -0,0 +1,18 @@
def safe(q1, q2):
(q1x, q1y) = q1
(q2x, q2y) = q2
return q1x != q2x and q1y != q2y and abs(q1x - q2x) != abs(q1y - q2y)
def possible_positions(current, n):
return ((*current, y) for y in range(n) if all(safe((len(current), y), q) for q in enumerate(current)))
def solutions_r(current, n = 8):
if len(current) == n:
yield current
return
for pos in possible_positions(current, n):
yield from solutions_r(pos, n)
def solutions(n = 8):
return solutions_r((), n)

View File

@@ -0,0 +1,7 @@
def l(n=9):
for x in range(1, n):
print(" " * (x % 2), "*")
def r(n=5):
for x in range(n, -1, -1):
print("*" * (x * 2 + 1))

1
CS1032/notes-2023-11-16 Normal file
View File

@@ -0,0 +1 @@

0
CS1032/notes-2023-11-17 Normal file
View File

View File

@@ -0,0 +1,4 @@
import sys
for line in sys.stdin:
print(line.split('#')[0].rstrip())

View File

@@ -0,0 +1,11 @@
#! /usr/bin/env python3
import sys, random
with open(sys.argv[1]) as words_f:
words = [word for line in words_f if 3 <= len(word := line.strip()) < 10 and word.lower() == word]
pair = []
while not 8 <= sum(map(len, pair)) <= 10:
pair = random.choices(words, k=2)
print(''.join(w.title() for w in pair))

View File

@@ -0,0 +1,6 @@
#! /usr/bin/env python3
import sys, re
redacted = re.compile(f"({'|'.join([s.strip() for s in open(sys.argv[1])])})")
for line in sys.stdin:
print(redacted.sub(lambda m: '*' * len(m.group(0)), line), end='')

View File

@@ -0,0 +1,9 @@
#! /usr/bin/env python3
sum = 0
while True:
i = input(f"[{sum:g}]: ")
if not i: break
try:
sum += float(i)
except ValueError: print(f"\t'{i}' is not a number")

View File

@@ -0,0 +1,33 @@
#! /usr/bin/env python3
def sort(list):
if len(list) <= 1: return list
pivot = list.pop()
return sort([v for v in list if v < pivot]) + [v for v in list if v == pivot] + [pivot] + sort([v for v in list if v > pivot])
def search(list, elem, start=0):
if list == [elem]:
return start
elif len(list) <= 1:
return None
i = len(list) // 2
pivot = list[i]
if elem > pivot:
return search(list[i:], elem, start = i + start)
elif elem < pivot:
return search(list[:i], elem, start=start)
elif elem == pivot:
return i + start
raise ValueError("Got NaN!")
if __name__ == '__main__':
l = []
while line := input('> '):
l.append(line)
i = search(sort(l), input('Goal: '))
if i:
print(f"Found at {i}")
else:
print("Not present")