개발일지

유효한 팰린드롬 본문

Algorithm

유효한 팰린드롬

wa_n 2023. 3. 13. 10:58
728x90
반응형

유효한 팰린드롬


앞에서 읽을 때나 뒤에서 읽을 때나 같은 문자열을 팰린드롬이라고 합니다.
문자열이 입력되면 해당 문자열이 팰린드롬이면 "YES", 아니면 “NO"를 출력하는 프로그램을 작성하세요.
단 회문을 검사할 때 알파벳만 가지고 회문을 검사하며, 대소문자를 구분하지 않습니다. 알파벳 이외의 문자들의 무시합니다.



▣ 입력설명

첫 줄에 정수 길이 100을 넘지 않는 공백이 없는 문자열이 주어집니다.



▣ 출력설명

첫 번째 줄에 팰린드롬인지의 결과를 YES 또는 NO로 출력합니다.



▣ 입력예제 1

found7, time: study; Yduts; emit, 7Dnuof


▣ 출력예제 1

YES







 function solution(s){
                let answer="YES";
                s=s.toLowerCase().replace(/[^a-z]/g, '');
   console.log(s, s.split(''))
                if(s.split('').reverse().join('')!==s) return "NO";
                return answer;
            }

            let str="found7, time: study; Yduts; emit, 7Dnuof";
            console.log(solution(str));




replace()
메서드는 어떤 패턴에 일치하는 일부 또는 모든 부분이 교체된 새로운 문자열을 반환합니다.
그 패턴은 문자열이나 정규식(RegExp)이 될 수 있으며, 교체 문자열은 문자열이나 모든 매치에 대해서 호출된 함수일 수 있습니다.



replace(/[^a-z]/g, '')

/ / : 이 슬래쉬 안쪽에서 정해진 값을 찾겠다
g : 글로벌 영역 처음부터 끝까지 다
[ ] : 괄호안의 문자들 중 하나
[^ ] : 괄호안의 문자를 제외한 것, 부정
a-z : 알파벳 a부터 z까지 찾는


알파벳 a~z가 아닌 값을 찾아서 replace메소드로 " "빈 문자열로 바꿔서 출력

728x90
반응형

'Algorithm' 카테고리의 다른 글

가장 큰 수  (0) 2023.03.23
뒤집은 소수  (0) 2023.03.14
숫자만 출력  (0) 2023.03.13
회문 문자열  (0) 2023.03.08
격자판 최대합  (0) 2023.03.07