문제
N개의 단어가 주어지면 각 단어를 뒤집어 출력하는 프로그램을 작성하세요.
▣ 입력설명
첫 줄에 자연수 N(3<=N<=20)이 주어집니다.
두 번째 줄부터 N개의 단어가 각 줄에 하나씩 주어집니다. 단어는 영어 알파벳으로만 구성되어 있습니다.
▣ 출력설명
N개의 단어를 입력된 순서대로 한 줄에 하나씩 뒤집어서 출력합니다.
▣ 입력예제 1
3
good
Time
Big
▣ 출력예제 1
doog
emiT
giB
풀이
두 가지 방식으로 풀 수 있다.
코드
1) StringBuilder 사용
import java.util.ArrayList;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
ArrayList<String> answer = new ArrayList<>();
int n = in.nextInt();
for(int i=0; i<n; i++) {
String s = in.next();
String rs = new StringBuilder(s).reverse().toString();
answer.add(rs);
}
for(String rs : answer) {
System.out.println(rs);
}
}
}
2) toCharArray 사용. 맨 앞인덱스와 맨 뒤인덱스 값을 바꿔나가며 중앙에서 끝나면 멈춘다.
import java.util.ArrayList;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
ArrayList<String> answer = new ArrayList<>();
int n = in.nextInt();
for(int i=0; i<n; i++) {
char[] c = in.next().toCharArray();
int lt=0, rt=c.length-1;
while(lt < rt) {
char tmp = c[lt];
c[lt] = c[rt];
c[rt] = tmp;
lt++;
rt--;
}
answer.add(String.valueOf(c));//char배열 String화
}
for(String rs : answer) {
System.out.println(rs);
}
}
}
'PS(Java) > 인프런 강의 문제' 카테고리의 다른 글
[PS] 인프런 강의 - 문자열 6. 중복 문자 제거 (0) | 2022.10.10 |
---|---|
[PS] 인프런 강의 - 문자열 5. 특정 문자 뒤집기 (0) | 2022.10.10 |
[PS] 인프런 강의 - 문자열 3. 문장 속 단어(indexOf(), substring()) (0) | 2022.10.10 |
[PS] 인프런 강의 - 문자열 2. 대소문자 변환 (0) | 2022.10.10 |
[PS] 인프런 강의 - 문자열 1. 문자 찾기 (0) | 2022.10.09 |