Skip to content

feat: add solutions to lc problem: No.1328 #1278

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 1 commit into from
Jul 23, 2023
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
109 changes: 108 additions & 1 deletion solution/1300-1399/1328.Break a Palindrome/README.md
Original file line number Diff line number Diff line change
@@ -41,22 +41,129 @@

<!-- 这里可写通用的实现逻辑 -->

**方法一:贪心**

我们先判断字符串的长度是否为 $1$,若是则直接返回空串。

否则,我们从左到右遍历字符串的前半部分,找到第一个不为 `'a'` 的字符,将其改为 `'a'` 即可。如果不存在这样的字符,那么我们将最后一个字符改为 `'b'` 即可。

时间复杂度 $O(n)$,空间复杂度 $O(n)$。其中 $n$ 为字符串的长度。

<!-- tabs:start -->

### **Python3**

<!-- 这里可写当前语言的特殊实现逻辑 -->

```python

class Solution:
def breakPalindrome(self, palindrome: str) -> str:
n = len(palindrome)
if n == 1:
return ""
s = list(palindrome)
i = 0
while i < n // 2 and s[i] == "a":
i += 1
if i == n // 2:
s[-1] = "b"
else:
s[i] = "a"
return "".join(s)
```

### **Java**

<!-- 这里可写当前语言的特殊实现逻辑 -->

```java
class Solution {
public String breakPalindrome(String palindrome) {
int n = palindrome.length();
if (n == 1) {
return "";
}
char[] cs = palindrome.toCharArray();
int i = 0;
while (i < n / 2 && cs[i] == 'a') {
++i;
}
if (i == n / 2) {
cs[n - 1] = 'b';
} else {
cs[i] = 'a';
}
return String.valueOf(cs);
}
}
```

### **C++**

```cpp
class Solution {
public:
string breakPalindrome(string palindrome) {
int n = palindrome.size();
if (n == 1) {
return "";
}
int i = 0;
while (i < n / 2 && palindrome[i] == 'a') {
++i;
}
if (i == n / 2) {
palindrome[n - 1] = 'b';
} else {
palindrome[i] = 'a';
}
return palindrome;
}
};
```

### **Go**

```go
func breakPalindrome(palindrome string) string {
n := len(palindrome)
if n == 1 {
return ""
}
i := 0
s := []byte(palindrome)
for i < n/2 && s[i] == 'a' {
i++
}
if i == n/2 {
s[n-1] = 'b'
} else {
s[i] = 'a'
}
return string(s)
}
```

### **TypeScript**

```ts
function breakPalindrome(palindrome: string): string {
const n = palindrome.length;
if (n === 1) {
return '';
}
const s = palindrome.split('');
let i = 0;
while (i < n >> 1 && s[i] === 'a') {
i++;
}
if (i == n >> 1) {
s[n - 1] = 'b';
} else {
s[i] = 'a';
}
return s.join('');
}
```

### **...**
101 changes: 100 additions & 1 deletion solution/1300-1399/1328.Break a Palindrome/README_EN.md
Original file line number Diff line number Diff line change
@@ -43,13 +43,112 @@ Of all the ways, &quot;aaccba&quot; is the lexicographically smallest.
### **Python3**

```python

class Solution:
def breakPalindrome(self, palindrome: str) -> str:
n = len(palindrome)
if n == 1:
return ""
s = list(palindrome)
i = 0
while i < n // 2 and s[i] == "a":
i += 1
if i == n // 2:
s[-1] = "b"
else:
s[i] = "a"
return "".join(s)
```

### **Java**

```java
class Solution {
public String breakPalindrome(String palindrome) {
int n = palindrome.length();
if (n == 1) {
return "";
}
char[] cs = palindrome.toCharArray();
int i = 0;
while (i < n / 2 && cs[i] == 'a') {
++i;
}
if (i == n / 2) {
cs[n - 1] = 'b';
} else {
cs[i] = 'a';
}
return String.valueOf(cs);
}
}
```

### **C++**

```cpp
class Solution {
public:
string breakPalindrome(string palindrome) {
int n = palindrome.size();
if (n == 1) {
return "";
}
int i = 0;
while (i < n / 2 && palindrome[i] == 'a') {
++i;
}
if (i == n / 2) {
palindrome[n - 1] = 'b';
} else {
palindrome[i] = 'a';
}
return palindrome;
}
};
```

### **Go**

```go
func breakPalindrome(palindrome string) string {
n := len(palindrome)
if n == 1 {
return ""
}
i := 0
s := []byte(palindrome)
for i < n/2 && s[i] == 'a' {
i++
}
if i == n/2 {
s[n-1] = 'b'
} else {
s[i] = 'a'
}
return string(s)
}
```

### **TypeScript**

```ts
function breakPalindrome(palindrome: string): string {
const n = palindrome.length;
if (n === 1) {
return '';
}
const s = palindrome.split('');
let i = 0;
while (i < n >> 1 && s[i] === 'a') {
i++;
}
if (i == n >> 1) {
s[n - 1] = 'b';
} else {
s[i] = 'a';
}
return s.join('');
}
```

### **...**
19 changes: 19 additions & 0 deletions solution/1300-1399/1328.Break a Palindrome/Solution.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
class Solution {
public:
string breakPalindrome(string palindrome) {
int n = palindrome.size();
if (n == 1) {
return "";
}
int i = 0;
while (i < n / 2 && palindrome[i] == 'a') {
++i;
}
if (i == n / 2) {
palindrome[n - 1] = 'b';
} else {
palindrome[i] = 'a';
}
return palindrome;
}
};
17 changes: 17 additions & 0 deletions solution/1300-1399/1328.Break a Palindrome/Solution.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
func breakPalindrome(palindrome string) string {
n := len(palindrome)
if n == 1 {
return ""
}
i := 0
s := []byte(palindrome)
for i < n/2 && s[i] == 'a' {
i++
}
if i == n/2 {
s[n-1] = 'b'
} else {
s[i] = 'a'
}
return string(s)
}
19 changes: 19 additions & 0 deletions solution/1300-1399/1328.Break a Palindrome/Solution.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
class Solution {
public String breakPalindrome(String palindrome) {
int n = palindrome.length();
if (n == 1) {
return "";
}
char[] cs = palindrome.toCharArray();
int i = 0;
while (i < n / 2 && cs[i] == 'a') {
++i;
}
if (i == n / 2) {
cs[n - 1] = 'b';
} else {
cs[i] = 'a';
}
return String.valueOf(cs);
}
}
14 changes: 14 additions & 0 deletions solution/1300-1399/1328.Break a Palindrome/Solution.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
class Solution:
def breakPalindrome(self, palindrome: str) -> str:
n = len(palindrome)
if n == 1:
return ""
s = list(palindrome)
i = 0
while i < n // 2 and s[i] == "a":
i += 1
if i == n // 2:
s[-1] = "b"
else:
s[i] = "a"
return "".join(s)
17 changes: 17 additions & 0 deletions solution/1300-1399/1328.Break a Palindrome/Solution.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
function breakPalindrome(palindrome: string): string {
const n = palindrome.length;
if (n === 1) {
return '';
}
const s = palindrome.split('');
let i = 0;
while (i < n >> 1 && s[i] === 'a') {
i++;
}
if (i == n >> 1) {
s[n - 1] = 'b';
} else {
s[i] = 'a';
}
return s.join('');
}