我的命令行有两个输入,一个素数 p 和一个正整数 n。我将它们以 GF(p^n) 的形式放在伽罗瓦域中。
我的目标是打印出该字段的所有元素、加法和乘法。
我可以打印出字段的元素,但是如何获得加法和乘法?如果 p 和 n 为 2,我希望它们是这样的:
(0) + (0) = 0
(0) + (x) = x
(0) + (x + 1) = x + 1
(0) + (1) = 1
(x) + (0) = x
(x) + (x) = 0
(x) + (x + 1) = 1
(x) + (1) = x + 1
(x + 1) + (0) = x + 1
(x + 1) + (x) = 1
(x + 1) + (x + 1) = 0
(x + 1) + (1) = x
(1) + (0) = 1
(1) + (x) = x + 1
(1) + (x + 1) = x
到目前为止,这是我的代码:
import sys
p = int(sys.argv[1])
n = int(sys.argv[2])
k = GF(p**n, 'x')
for i,x in enumerate(k): print x
print '(%s) + (%s) = %s' % (i, j, i + j)