Rozwiązanie zadania "CRC" #24

Closed
s426211 wants to merge 8 commits from (deleted):zad3 into master
Showing only changes of commit 538b8393d9 - Show all commits

30
main.py
View File

@ -1,6 +1,5 @@
if __name__ == "__main__": def encode(M):
message = format(int.from_bytes(M.encode(), "big"), "b")
message = format(int.from_bytes(input().encode("ASCII"), "big"), "b")
generator = "10001000000100001" generator = "10001000000100001"
gen_deg = len(generator) gen_deg = len(generator)
@ -23,9 +22,28 @@ if __name__ == "__main__":
message = message[1:] message = message[1:]
else: else:
chunk = message[:gen_deg] chunk = message[:gen_deg]
if len(chunk) < gen_deg: if len(chunk) < gen_deg:
print(hex(int(chunk, 2))) chunk = "00" + chunk
break return chr(int(chunk[:8], 2)) + chr(int(chunk[8:], 2))
remainder = format(int(chunk, 2) ^ int(generator, 2), "b") remainder = format(int(chunk, 2) ^ int(generator, 2), "b")
message = remainder + message[gen_deg:] message = remainder + message[gen_deg:]
def decode(N):
message = format(int.from_bytes(N.encode(), "big"), "b")
while len(message) % 8 != 0:
message = "0" + message
if __name__ == "__main__":
M = input()
N = encode(M)
# print(N)
decode(M+N)
# 0011110110111000
# 11000010111100101111001001111011100001010111000
# 0011110110111000