-
[백준/BOJ] 1259번 : 팬린드롬수 (JAVA / 자바)백준 2022. 2. 15. 21:15
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/1259
- 문제 -
난이도 브론즈 1 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
풀이 방법
방법은 여러가지 있지만 대부분 처음에 생각하는 것은 입력된 값을 하나하나 뒤집어 저장한 다음 비교하는 것일거다. 하지만 우리 자바에게는 매우 좋고 훌륭한 reverse라는 함수가 있다.(저 방법이 틀린 것은 아니다. 필자도 처음에 저렇게도 해서 맞았지만 코드 면에서 가독성이 좋은건 reverse 사용이였다.) 하지만 이 reverse도 collections, StringBuffered, StringBuilder 등 여러가지 있다. 필자는 이중 StringBuilder를 사용하겠다. 아무래도 이게 많이 익숙하니.
StringBuilder로 문자열을 뒤집었으면 이제 입력값과 비교해서 같으면 yes 다르면 no를 출력한다.
-풀이-
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); //무한루프 while(true) { String S = br.readLine(); //StringBuilder를 선언하면서 입력값인 S를 저장한다. StringBuilder sb = new StringBuilder(S); //StringBuilder 내장 함수 reverse를 사용하지만 원래는 같은 StringBuilder에 저장가능하기에 //String으로 변환해서 저장한다. 그것이 뒤에 .toString()이다. String Sreverse = sb.reverse().toString(); //0 입력시 무한루프 종료 if(S.equals("0")) break; //두 문자열을 비교 if(S.equals(Sreverse)) { System.out.println("yes"); }else{ System.out.println("no"); } } } }
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수분들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠습니다.
'백준' 카테고리의 다른 글
[백준/BOJ] 1037번 : 약수 (JAVA / 자바) (0) 2022.02.16 [백준/BOJ] 1296번 : 팀 이름 정하기 (JAVA / 자바) (0) 2022.02.16 [백준/BOJ] 1252번 : 이진수 덧셈 (JAVA / 자바) (0) 2022.02.15 [백준/BOJ] 1233번 : 주사위 (JAVA / 자바) (0) 2022.02.15 [백준/BOJ] 1225번 : 이상한 곱셈 (JAVA / 자바) (0) 2022.02.15