Offer to come, dig friends take it! I am participating in the 2022 Spring Recruit Punch card activity. Click here for details.
More and more testing positions, in addition to basic functional testing, programming background, scripting experience to stand out.
How can we improve our programming ability, brush LeetCode is one of the best way, not most of the words, brush the topic to go ~
I. Title Description:
-
The subject content
-
The subject sample
-
title
- They tell us it’s a positive integer in decimal
- Requires binary, 0 and 1 alternating for positive integers
- Return False if the binary contiguous arrays are identical
Ii. Analysis of Ideas:
We have this problem, similar to the problem we did yesterday with 67. Binary summation, and the idea is as follows:
- The decimal integer is first converted to base 2
- Convert binary to string
- Use the for loop to traverse the binary string
- If Bin[i-1] and Bin[I] are equal, return False.
For converting from decimal to binary, let’s first look at the conversion principle. For example, 5–> binary 101
Along these lines, we wrote decimal to binary
S = ""
while n :
pre = n%2
S = S + str(pre)
n = n/2
print(S[::-1])
Copy the code
Converting from decimal to binary can also be done directly using the Python bin() method
Well, after that transformation, we have binary. Then the character alignment is traversed, and the complete code is as follows:
class Solution(object) :
def hasAlternatingBits(self, n) :
""" :type n: int :rtype: bool """
B = bin(n)
for i in range(1.len(str(B))):
if B[i-1] == B[i] :
return False
return True
Copy the code
We found that optimization can be done using a for loop with a time complexity of O(n). To make a judgment directly when converting binary, the code is as follows:
Time complexity O(logn), space complexity O(1)
class Solution(object) :
def hasAlternatingBits(self, n) :
""" :type n: int :rtype: bool """
tmp = 2
while n :
pre = n%2
if tmp == pre:
return False
tmp = pre
n = n/2
return True
Copy the code
Compared with the above methods, the fastest operation is to carry out bit operation, and the space complexity can be O(1) directly.
a = n ^ (n >> 1)
return a & (a + 1) = =0
Copy the code
Iii. Summary:
In this case, the AC records submitted by the first method are as follows:
The problem of base bit calculation, we can use the form of string to solve.
That’s the content of this episode. Please give us your thumbs up and comments. See you next time