369게임
https://school.programmers.co.kr/learn/courses/30/lessons/120895
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
1) 문제
my_string에서 인덱스 num1과 인덱스 num2에 해당하는 문자를 바꾼 문자열을 return 하도록
solution 함수를 완성해보세요.
1 < my_string의 길이 < 100
0 ≤ num1, num2 < my_string의 길이
my_string은 소문자로 이루어져 있습니다.
num1 ≠ num2
2) 예시
my_string | num1 | num2 | result |
---|---|---|---|
"hello" | 1 | 2 | "hello" |
"I love you" | 3 | 6 | "I l veoyou" |
입출력 예 #1
"hello"의 1번째 인덱스인 "e"와 2번째 인덱스인 "l"을 바꾸면 "hlelo"입니다.
입출력 예 #2
"I love you"의 3번째 인덱스 "o"와 " "(공백)을 바꾸면 "I l veoyou"입니다.
3) 풀이
1. 클래스 선언을 해줍니다
● class Solution {
클래스명은 대문자로 시작해야하고, 정답이라는 의미로 Solution이라는 단어를 사용하였습니다.
2. 문자열 my_string, 정수 num1과 num2를 매개변수로 하는 solution 메소드를 선언합니다.
solution은 문자열을 반환하므로 데이터타입을 String로 합니다.
● public String solution(String my_string, int num1, int num2) {
3. 제한사항을 확인하고, 만족하지 않는다면 예외처리합니다.
● if(1 >= my_string.length() || my_string.length() >= 100 || 0 > num1 || num2 >= my_string.length() || num1 == num2) {
throw new IllegalArgumentException("제한사항을 확인하세요");
}
4. 정답이 될 문자열 answer를 생성하고 초기화합니다.
● String answer = "";
5. 우선 my_String을 toCharArray 메소드를 이용해서 문자배열 ch로 만듭니다.
그리고 그 문자배열은 불변하지않으므로 값을 변경할 수 있습니다.
ch 문자배열의 num1 인덱스값은 my_string의 num2 인덱스 값으로하고,
ch 문자배열의 num2 인덱스값은 my_string의 num1 인덱스 값으로 합니다.
그리고 answer 문자열은 ch문자배열을 String으로 변환하고, 반환합니다.
● char[] ch = my_string.toCharArray();
ch[num1] = my_string.charAt(num2);
ch[num2] = my_string.charAt(num1);
answer = String.valueOf(ch);
return answer;
4) 코드
class Solution {
public String solution(String my_string, int num1, int num2) {
String answer = "";
if(1 >= my_string.length() || my_string.length() >= 100 || 0 > num1 || num2 >= my_string.length() || num1 == num2){
throw new IllegalArgumentException("제한사항을 확인하세요");
}
char[] ch = my_string.toCharArray();
ch[num1] = my_string.charAt(num2);
ch[num2] = my_string.charAt(num1);
answer = String.valueOf(ch);
return answer;
}
}
5) 느낀점
마지막 answer를 return하는 부분을 return ch.toString();으로 해도 되겠다는 생각이 바로 들었습니다.
비슷한 문제를 많이 풀어봤구나 하는 생각이 들며, toCharArray 메소드를 써봐서 좋았던 문제입니다.
늘 풀던 방식인 StringBuilder도 한번 코드 만들어보았습니다.
class Solution {
public String solution(String my_string, int num1, int num2) {
StringBuilder sb = new StringBuilder(my_string);
char temp = sb.charAt(num1);
sb.setCharAt(num1, sb.charAt(num2));
sb.setCharAt(num2, temp);
return sb.toString();
}
}
setCharAt(A,B)를 이용해서 A번째 인덱스의 값을 B로 바꾸는 방식을 취했습니다.
'Programmers Coding Test > Java' 카테고리의 다른 글
[프로그래머스 120897] Java - 코딩테스트 입문 / 약수 구하기 (0) | 2024.03.06 |
---|---|
[프로그래머스 120896] Java - 코딩테스트 입문 / 한 번만 등장한 문자 (0) | 2024.03.06 |
[프로그래머스 120891] Java - 코딩테스트 입문 / 369게임 (1) | 2024.02.19 |
[프로그래머스 120890] Java - 코딩테스트 입문 / 가까운 수 (0) | 2024.02.19 |
[프로그래머스 120888] Java - 코딩테스트 입문 / 중복된 문자 제거 (0) | 2024.02.19 |