214. Shortest Palindrome
Дана stringa s. Вы можете преобразовать s в палиндром, добавив символы в начало строки.
return самый короткий палиндром, который можно получить, выполняя это преобразование.
Esempio:
Input: s = "aacecaaa"
Output: "aaacecaaa"
C# soluzione
abbinato/originalepublic class Solution {
public string ShortestPalindrome(string s) {
int n = s.Length;
char[] revArray = s.ToCharArray();
Array.Reverse(revArray);
string rev = new string(revArray);
for (int i = 0; i < n; i++) {
if (s.Substring(0, n - i) == rev.Substring(i)) {
return rev.Substring(0, i) + s;
}
}
return "";
}
}
C++ soluzione
bozza automatica, rivedere prima dell'invio#include <bits/stdc++.h>
using namespace std;
// Auto-generated C++ draft from the C# solution. Review containers, LINQ and helper types before submit.
class Solution {
public:
public string ShortestPalindrome(string s) {
int n = s.size();
char[] revArray = s.ToCharArray();
Array.Reverse(revArray);
string rev = new string(revArray);
for (int i = 0; i < n; i++) {
if (s.Substring(0, n - i) == rev.Substring(i)) {
return rev.Substring(0, i) + s;
}
}
return "";
}
}
Java soluzione
abbinato/originaleclass Solution {
public String shortestPalindrome(String s) {
int n = s.length();
String rev = new StringBuilder(s).reverse().toString();
for (int i = 0; i < n; i++) {
if (s.substring(0, n - i).equals(rev.substring(i))) return (
rev.substring(0, i) + s
);
}
return "";
}
}
JavaScript soluzione
abbinato/originaleclass Solution {
shortestPalindrome(s) {
const n = s.length;
const rev = s.split('').reverse().join('');
for (let i = 0; i < n; i++) {
if (s.substring(0, n - i) === rev.substring(i)) {
return rev.substring(0, i) + s;
}
}
return "";
}
}
Python soluzione
abbinato/originaleclass Solution:
def shortestPalindrome(self, s: str) -> str:
n = len(s)
rev = s[::-1]
for i in range(n):
if s[: n - i] == rev[i:]:
return rev[:i] + s
return ""
Go soluzione
abbinato/originalepackage main
import (
"fmt"
"strings"
)
func shortestPalindrome(s string) string {
n := len(s)
rev := reverseString(s)
for i := 0; i < n; i++ {
if s[:n-i] == rev[i:] {
return rev[:i] + s
}
}
return ""
}
func reverseString(s string) string {
runes := []rune(s)
for i, j := 0, len(runes)-1; i < j; i, j = i+1, j-1 {
runes[i], runes[j] = runes[j], runes[i]
}
return string(runes)
}
Algorithm
1️⃣
Создание обратной строки:
Создайте обратную строку rev от исходной строки s, чтобы использовать её для сравнения.
2️⃣
Итерация для поиска наибольшего палиндрома:
Перебирайте индекс i от 0 до size(s) - 1.
Для каждой итерации проверяйте, равна ли substring s от начала до n - i подстроке rev от i до конца строки.
Если Testo выполняется, это означает, что substring s от начала до n - i является палиндромом, так как rev является обратной строкой s.
3️⃣
Возврат результата:
Как только найден наибольший палиндром, возвращайте строку, состоящую из обратной подстроки rev от начала до i + исходная stringa s.
😎
Vacancies for this task
offerte attive with overlapping task tags are mostrati.