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/59b9a/59b9a5b605ecafec780d7b85f50eb58b79c6c255" alt=""
data:image/s3,"s3://crabby-images/55480/55480b71d2660d86f2553bf0f657eaf176a12d4f" alt=""
data:image/s3,"s3://crabby-images/5865d/5865dce8638d3e064731254151d7a4c072e697af" alt=""
data:image/s3,"s3://crabby-images/2d948/2d948201458bd4b863b1dde20dc8379cef42c789" alt=""
data:image/s3,"s3://crabby-images/ace93/ace9318ed686065f25334691694a6d1bdd68f061" alt=""
data:image/s3,"s3://crabby-images/b133b/b133b55d8d2d841339dc3966f9a876fc6d59899f" alt=""
data:image/s3,"s3://crabby-images/1b5c6/1b5c6b3066cd300f2688a453b89fdb827814172f" alt=""
data:image/s3,"s3://crabby-images/1d763/1d763acd971d90a7204cf2f5f81a8570c67e5788" alt=""
data:image/s3,"s3://crabby-images/7ecb6/7ecb6d7a77d9be1d54420669132ada9fc585e051" alt=""
data:image/s3,"s3://crabby-images/34e25/34e254a60a28c813509f1a9c065f4e945e51d22d" alt=""
'해외 여행' 카테고리의 다른 글
나는솔로 22기 돌싱특집 직업 나이 상철 광수 순자 포스코 (0) | 2024.09.06 |
---|---|
나는솔로 22기 직업 인스타 갤러리 돌싱특집 영수 광수 순자 포스코 (0) | 2024.09.06 |
나의 정신건강과 성공 이야기: ADHD, 우울증, 불안증을 극복한 대기업 합격기 (0) | 2024.09.05 |
나는솔로 22기 직업 인스타 갤러리 돌싱특집 영수 광수 순자 포스코 (0) | 2024.09.04 |
나는솔로 22기 돌싱특집 직업 나이 상철 광수 순자 포스코 (0) | 2024.09.03 |
댓글