[python] 파이썬에서 값을 토글하는 방법

0와 사이를 전환하는 가장 효율적인 방법은 무엇입니까 1?



답변

NOT을 사용한 솔루션

값이 부울 인 경우 가장 빠른 방법은 not 연산자 를 사용하는 입니다.

>>> x = True
>>> x = not x        # toggle
>>> x
False
>>> x = not x        # toggle
>>> x
True
>>> x = not x        # toggle
>>> x
False

빼기를 사용하는 솔루션

값이 숫자 인 경우 합계에서 빼는 것이 값을 전환하는 간단하고 빠른 방법입니다.

>>> A = 5
>>> B = 3
>>> total = A + B
>>> x = A
>>> x = total - x    # toggle
>>> x
3
>>> x = total - x    # toggle
>>> x
5
>>> x = total - x    # toggle
>>> x
3

XOR을 사용한 솔루션

값이 01 사이에서 전환되면 비트 배타적 또는 다음을 사용할 수 있습니다 .

>>> x = 1
>>> x ^= 1
>>> x
0
>>> x ^= 1
>>> x
1

이 기술은 모든 정수 쌍으로 일반화됩니다. xor-by-one 단계는 xor-by-precomputed-constant로 대체됩니다.

>>> A = 205
>>> B = -117
>>> t = A ^ B        # precomputed toggle constant
>>> x = A
>>> x ^= t           # toggle
>>> x
-117
>>> x ^= t           # toggle
>>> x
205
>>> x ^= t           # toggle
>>> x
-117

(이 아이디어는 Nick Coghlan이 제출했으며 나중에 @zxxc에 의해 일반화되었습니다.)

사전을 사용한 솔루션

값이 해시 가능한 경우 사전을 사용할 수 있습니다.

>>> A = 'xyz'
>>> B = 'pdq'
>>> d = {A:B, B:A}
>>> x = A
>>> x = d[x]         # toggle
>>> x
'pdq'
>>> x = d[x]         # toggle
>>> x
'xyz'
>>> x = d[x]         # toggle
>>> x
'pdq'

조건식을 사용한 솔루션

가장 느린 방법은 조건식 을 사용하는 것입니다 .

>>> A = [1,2,3]
>>> B = [4,5,6]
>>> x = A
>>> x = B if x == A else A
>>> x
[4, 5, 6]
>>> x = B if x == A else A
>>> x
[1, 2, 3]
>>> x = B if x == A else A
>>> x
[4, 5, 6]

itertools를 사용한 솔루션

두 개 이상의 값이있는 경우 itertools.cycle () 함수는 연속 값 사이를 전환하는 일반적인 빠른 방법을 제공합니다.

>>> import itertools
>>> toggle = itertools.cycle(['red', 'green', 'blue']).next
>>> toggle()
'red'
>>> toggle()
'green'
>>> toggle()
'blue'
>>> toggle()
'red'
>>> toggle()
'green'
>>> toggle()
'blue'

Python 3에서는 next()메서드가로 변경 __next__()되었으므로 첫 번째 줄은 다음과 같이 작성됩니다.toggle = itertools.cycle(['red', 'green', 'blue']).__next__


답변

나는 항상 다음을 사용합니다.

p^=True

p가 부울이면 true와 false 사이에서 전환됩니다.


답변

직관적이지 않은 또 다른 방법이 있습니다. 아름다움은 단지 두 개의 값이 아닌 여러 값을 순환 할 수 있다는 것입니다. [0,1]

두 값의 경우 (토글 링)

>>> x=[1,0]
>>> toggle=x[toggle]

여러 값의 경우 (예 : 4)

>>> x=[1,2,3,0]
>>> toggle=x[toggle]

이 솔루션이 거의 빠르다고 생각하지 않았습니다.

>>> stmt1="""
toggle=0
for i in xrange(0,100):
    toggle = 1 if toggle == 0 else 0
"""
>>> stmt2="""
x=[1,0]
toggle=0
for i in xrange(0,100):
    toggle=x[toggle]
"""
>>> t1=timeit.Timer(stmt=stmt1)
>>> t2=timeit.Timer(stmt=stmt2)
>>> print "%.2f usec/pass" % (1000000 * t1.timeit(number=100000)/100000)
7.07 usec/pass
>>> print "%.2f usec/pass" % (1000000 * t2.timeit(number=100000)/100000)
6.19 usec/pass
stmt3="""
toggle = False
for i in xrange(0,100):
    toggle = (not toggle) & 1
"""
>>> t3=timeit.Timer(stmt=stmt3)
>>> print "%.2f usec/pass" % (1000000 * t3.timeit(number=100000)/100000)
9.84 usec/pass
>>> stmt4="""
x=0
for i in xrange(0,100):
    x=x-1
"""
>>> t4=timeit.Timer(stmt=stmt4)
>>> print "%.2f usec/pass" % (1000000 * t4.timeit(number=100000)/100000)
6.32 usec/pass


답변

not운영자가 당신의 변수를 부정 (이미이 아닌 경우 부울로 변환). 당신은 할 수 아마도 사용 10상호 교환과 함께 True하고 False그래서 그냥 그것을 부정 :

toggle = not toggle

그러나 두 개의 임의 값을 사용하는 경우 인라인을 사용하십시오 if.

toggle = 'a' if toggle == 'b' else 'b'


답변

1과 0 사이에서 이렇게

1-x 

x는 1 또는 0을 취할 수 있습니다.


답변

삼각 접근 , 단지 때문에 sincos기능이 시원하다.

여기에 이미지 설명 입력

>>> import math
>>> def generator01():
...     n=0
...     while True:
...         yield abs( int( math.cos( n * 0.5 * math.pi  ) ) )
...         n+=1
...
>>> g=generator01()
>>> g.next()
1
>>> g.next()
0
>>> g.next()
1
>>> g.next()
0


답변

놀랍게도 모듈로 2 :

In : x = (x + 1)  % 2 ; x
Out: 1

In : x = (x + 1)  % 2 ; x
Out: 0

In : x = (x + 1)  % 2 ; x
Out: 1

In : x = (x + 1)  % 2 ; x
Out: 0

이는와 동일 x = x - 1하지만 모듈로 기술의 장점은 그룹의 크기 또는 간격의 길이가 2 개 요소보다 클 수 있다는 것입니다. 따라서 루프 오버를위한 라운드 로빈 인터리빙 방식과 유사합니다.

이제 2의 경우 토글이 조금 더 짧아 질 수 있습니다 (비트 연산자 사용).

x = x ^ 1