Python中的代数(比交换机更好的东西?)

wil*_*ade 1 python algebra

我已经构建了一个套接字服务器,用于侦听来自另一台客户机的命令(我无法访问的代码).客户端发送与键击相关的号码,并发送与修改键按下相关的修饰符代码.所以举个例子

shift=1
control=2
alt=4
win=8
Run Code Online (Sandbox Code Playgroud)

发送的修饰符代码始终是一个数字.例如,修饰符= 1.但是如果发送的密钥超过1个,则可以说modifier = 3(即shift + control).问题是我如何计算密钥的数量.

所以为了简单起见,我们使用a,b,c,d-规则只是组合中的一个.

因此,如果:

a=1
b=2
c=4
d=8
Run Code Online (Sandbox Code Playgroud)

然后这些是组合的总数:

a+b=> 3
a+c=> 5
a+d=> 9
b+d=> 10
c+b=> 6
c+d=> 12

a+b+c=> 7
a+b+d=> 11

a+b+c+d=> 15
Run Code Online (Sandbox Code Playgroud)

那么在Python中计算n的最佳方法是什么?开关?

switch(n):
    case 3:
        print 'its a+b'
     case 5:
         print 'its a+c'
Run Code Online (Sandbox Code Playgroud)

...等等..

一定有更好的方法吗?

jon*_*rpe 7

您可以使用按位运算的强大功能:

def switches(n, num=4):
    return [n & (2**i) > 0 for i in range(num)]
Run Code Online (Sandbox Code Playgroud)

这将返回一个列表,其中每个项都是一个布尔值,表示是否按下了该开关:

>>> switches(10)
[False, True, False, True]
#  a      b     c      d 
Run Code Online (Sandbox Code Playgroud)

这就是为什么组件都是2的幂 - 当你将总数视为二进制数(注意颠倒顺序)时,它使访问每个开关的值变得微不足道:

>>> format(10, 'b') # show 10 as a binary number
'1010'
#8421
#dcba
Run Code Online (Sandbox Code Playgroud)

要显示所有选项:

>>> for i in range(2**4):
    print(i, '\t', format(i, '04b'))


0    0000 # no switches
1    0001 # a only
2    0010
3    0011
4    0100
5    0101
6    0110
7    0111 # a, b and c
8    1000
9    1001
10   1010 # b and d
11   1011
12   1100
13   1101
14   1110
15   1111 # all switches
Run Code Online (Sandbox Code Playgroud)