Here's a solution to convert the given string `S` into a palindrome by replacing question marks with lowercase letters, or returning "NO" if it's not possible:
```python
def solution(S):
S = list(S) # Convert string to list for mutability
N = len(S)
for i in range((N + 1) // 2):
left, right = S[i], S[N - 1 - i]
if left == '?' and right == '?':
S[i] = S[N - 1 - i] = 'a' # Replace both '?' with 'a'
elif left == '?':
S[i] = right # Replace '?' on the left with the right character
elif right == '?':
S[N - 1 - i] = left # Replace '?' on the right with the left character
elif left != right:
return "NO" # If characters do not match and are not '?', it's impossible
return ''.join(S) # Convert list back to string and return
# Examples
print(solution("?ab??a")) # Output: "aabbaa"
print(solution("bab??a")) # Output: "NO"
print(solution("?a?")) # Output: "aaa" or "aza"
```
### Explanation:
1. **Convert the String to a List**: This makes the string mutable, allowing for in-place modifications.
2. **Iterate Over the First Half of the String**: Since a palindrome reads the same forward and backward, you only need to check and modify the first half.
3. **Replace Question Marks**:
- If both characters at positions `i` and `N-1-i` are '?', replace both with 'a'.
- If only one character is '?', replace it with the corresponding character from the other half.
- If both characters are not '?', check if they are equal; if not, return "NO".
4. **Convert Back to String and Return**: After processing, convert the list back to a string.
This approach ensures correctness by handling all possible cases where question marks need to be replaced to form a palindrome. If it detects any impossible condition, it promptly returns "NO".
data:image/s3,"s3://crabby-images/842ea/842ea721c3c724fc087decd9d133378520392441" alt=""
data:image/s3,"s3://crabby-images/137c9/137c9b2e9635c6caf55641433dad0b2bf0565114" alt=""
data:image/s3,"s3://crabby-images/3d29e/3d29e1e9a4f7f42c6abf9429f68962ffe9d850ea" alt=""
data:image/s3,"s3://crabby-images/df122/df1227ea65adda1cabca46e5468790bec387f88d" alt=""
data:image/s3,"s3://crabby-images/1adde/1addedc7fbda0270bf4d61c09544b922cb3449fd" alt=""
data:image/s3,"s3://crabby-images/4e640/4e640085fb82cefd6074e0c9cfe017f60a80bd7d" alt=""
data:image/s3,"s3://crabby-images/57053/570534da48ad9c7f1811c7d7fe79c91d83359aa9" alt=""
data:image/s3,"s3://crabby-images/dad60/dad605bb78c8ec85812c88f7772b4945214ce0a6" alt=""
data:image/s3,"s3://crabby-images/10ed5/10ed5e1eb3e12642d6e680256aa42db8576acebd" alt=""
data:image/s3,"s3://crabby-images/a4e73/a4e731960cbd925090d84363a12456d8b6fb685f" alt=""
'대기업 일상' 카테고리의 다른 글
네이버 애드포스트 수익 블로그 티스토리 애드센스 (0) | 2024.08.22 |
---|---|
유튜브나 다른 매체에서 나오는 의견들은 일반적으로 흥미를 끌기 위해 과장 (0) | 2024.08.22 |
마케팅 담당자로 면접을 볼 때 나올 수 있는 질문들은 크게 네 가지 카테고리 (0) | 2024.08.22 |
마케팅 담당자로 면접을 볼 때 나올 수 있는 질문들은 크게 네 가지 카테고리 (0) | 2024.08.22 |
사람에게는 장단점이 있기 마련이지. 네가 만났던 그 남자들이 속이 좁았다 (0) | 2024.08.22 |
댓글