슈콩

[SWEA] 팰린드롬 문제 본문

Algorithms/SWEA

[SWEA] 팰린드롬 문제

shukong 2025. 11. 15. 16:45

 

 

[문제]

https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AYtrCJQaDb4DFAR-

 

SW Expert Academy

SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!

swexpertacademy.com

 

 

 

[소스 코드]

import java.io.*;
import java.util.*;
public class Solution {
	public static void main(String[] args) throws IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st;
		StringBuilder sb;
		int T = Integer.parseInt(br.readLine());
		for(int tc=1;tc<=T;tc++) {
			st = new StringTokenizer(br.readLine());
			int n = Integer.parseInt(st.nextToken());
			int m = Integer.parseInt(st.nextToken());
			String[] words = new String[n];
			for(int i=0;i<n;i++) {
				words[i] = br.readLine();
			}
			HashSet<String> hs = new HashSet<>();
			int result = 0;
			boolean check = false;
			for(int i=0;i<n;i++) {
				sb = new StringBuilder(words[i]).reverse();
				if(hs.contains(words[i])) {
					result += m * 2; 
				} 
				hs.add(String.valueOf(sb));
				if(!check && palindrome(words[i])) {
					result += m;
					check = true;
				}
			}
			System.out.println("#"+tc+" "+result);
		}
	}
	private static boolean palindrome(String s) {
		for(int i=0;i<s.length()/2;i++) {
			if(s.charAt(i)!=s.charAt(s.length()-1-i)) return false;
		}
		return true;
	}
}

'Algorithms > SWEA' 카테고리의 다른 글

[SWEA] 체스판 위의 룩 배치  (0) 2025.11.15
[SWEA] 무한 문자열  (0) 2025.11.15
[SWEA] 화섭이의 정수 나열  (0) 2025.11.15
[SWEA] 공평한 분배 2  (0) 2025.11.15
[SWEA] 사랑의 카운슬러  (0) 2025.11.15