728x90
반응형
문제 설명
문자열 my_string과 정수 s, e가 매개변수로 주어질 때, my_string에서 인덱스 s부터 인덱스 e까지를 뒤집은 문자열을 return 하는 solution 함수를 작성해 주세요.
제한사항
my_string은 숫자와 알파벳으로만 이루어져 있습니다.
1 ≤ my_string의 길이 ≤ 1,000
0 ≤ s ≤ e < my_string의 길이
입출력 예
my_string s e result
"Progra21Sremm3" 6 12 "ProgrammerS123"
"Stanley1yelnatS" 4 10 "Stanley1yelnatS"
입출력 설명
입출력 예 #1
예제 1번의 my_string에서 인덱스 6부터 인덱스 12까지를 뒤집은 문자열은 "ProgrammerS123"이므로 "ProgrammerS123"를 return 합니다.
입출력 예 #2
예제 2번의 my_string에서 인덱스 4부터 인덱스 10까지를 뒤집으면 원래 문자열과 같은 "Stanley1yelnatS"이므로 "Stanley1yelnatS"를 return 합니다.
내 풀이
Java
class Solution {
public String solution(String my_string, int s, int e) {
String answer = "";
char arr[] = my_string.toCharArray();
int k = s;
for(int i = e; i >= s; i--){
arr[i] = my_string.charAt(k++);
}
return new String(arr);
}
}
C
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
// 파라미터로 주어지는 문자열은 const로 주어집니다. 변경하려면 문자열을 복사해서 사용하세요.
char* solution(const char* my_string, int s, int e) {
// return 값은 malloc 등 동적 할당을 사용해주세요. 할당 길이는 상황에 맞게 변경해주세요.
char* answer = (char*)malloc(sizeof(char) * strlen(my_string) + 1);
strcpy(answer,my_string);
int k = e;
for(int i = s ; i <= e ;i++)
{
answer[i]= my_string[k--];
}
return answer;
}
Python
def solution(my_string, s, e):
answer = my_string[:s] + my_string[s:e+1][::-1] + my_string[e + 1:]
return answer
https://school.programmers.co.kr/learn/courses/30/lessons/181905
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
728x90
반응형
'코딩테스트 > 프로그래머스 기초' 카테고리의 다른 글
[코딩테스트 Lv.0] 문자열의 앞의 n글자 (4) | 2025.03.14 |
---|---|
[코딩테스트 Lv.0] 접두사인지 확인하기 (1) | 2025.03.14 |
[코딩테스트 Lv.0] 세로 읽기 (1) | 2025.03.13 |
[코딩테스트 Lv.0] qr code (2) | 2025.03.13 |
[코딩테스트 Lv.0] 문자 개수 세기 (1) | 2025.03.13 |