-
Notifications
You must be signed in to change notification settings - Fork 186
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1085 from 0xff-dev/1375
Add solution and test-cases for problem 1375
- Loading branch information
Showing
3 changed files
with
59 additions
and
9 deletions.
There are no files selected for viewing
42 changes: 42 additions & 0 deletions
42
leetcode/1301-1400/1375.Number-of-Times-Binary-String-Is-Prefix-Aligned/README.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
# [1375.Number of Times Binary String Is Prefix-Aligned][title] | ||
|
||
## Description | ||
You have a **1-indexed** binary string of length `n` where all the bits are `0` initially. We will flip all the bits of this binary string (i.e., change them from `0` to `1`) one by one. You are given a **1-indexed** integer array `flips` where `flips[i]` indicates that the bit at index `i` will be flipped in the `ith` step. | ||
|
||
A binary string is **prefix-aligned** if, after the `ith` step, all the bits in the **inclusive** range `[1, i]` are ones and all the other bits are zeros. | ||
|
||
Return the number of times the binary string is **prefix-aligned** during the flipping process. | ||
|
||
**Example 1:** | ||
|
||
``` | ||
Input: flips = [3,2,4,1,5] | ||
Output: 2 | ||
Explanation: The binary string is initially "00000". | ||
After applying step 1: The string becomes "00100", which is not prefix-aligned. | ||
After applying step 2: The string becomes "01100", which is not prefix-aligned. | ||
After applying step 3: The string becomes "01110", which is not prefix-aligned. | ||
After applying step 4: The string becomes "11110", which is prefix-aligned. | ||
After applying step 5: The string becomes "11111", which is prefix-aligned. | ||
We can see that the string was prefix-aligned 2 times, so we return 2. | ||
``` | ||
|
||
**Example 2:** | ||
|
||
``` | ||
Input: flips = [4,1,2,3] | ||
Output: 1 | ||
Explanation: The binary string is initially "0000". | ||
After applying step 1: The string becomes "0001", which is not prefix-aligned. | ||
After applying step 2: The string becomes "1001", which is not prefix-aligned. | ||
After applying step 3: The string becomes "1101", which is not prefix-aligned. | ||
After applying step 4: The string becomes "1111", which is prefix-aligned. | ||
We can see that the string was prefix-aligned 1 time, so we return 1. | ||
``` | ||
|
||
## 结语 | ||
|
||
如果你同我一样热爱数据结构、算法、LeetCode,可以关注我 GitHub 上的 LeetCode 题解:[awesome-golang-algorithm][me] | ||
|
||
[title]: https://leetcode.com/problems/number-of-times-binary-string-is-prefix-aligned | ||
[me]: https://github.com/kylesliu/awesome-golang-algorithm |
13 changes: 11 additions & 2 deletions
13
leetcode/1301-1400/1375.Number-of-Times-Binary-String-Is-Prefix-Aligned/Solution.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,14 @@ | ||
package Solution | ||
|
||
func Solution(x bool) bool { | ||
return x | ||
func Solution(flips []int) int { | ||
ans := 0 | ||
sum, cur := 0, 0 | ||
for i, f := range flips { | ||
sum += i + 1 | ||
cur += f | ||
if sum == cur { | ||
ans++ | ||
} | ||
} | ||
return ans | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters