Notice
Recent Posts
Recent Comments
Link
«   2024/09   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30
Tags
more
Archives
Today
Total
관리 메뉴

코드와이

[SW Expert Academy] 5550. 나는 개구리로소이다 본문

SW_Expert

[SW Expert Academy] 5550. 나는 개구리로소이다

코드와이 2021. 3. 24. 15:07

 

문제링크

swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AWWxqfhKAWgDFAW4

 

SW Expert Academy

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

swexpertacademy.com

 

package D4;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Stack;

public class 나는_개구리로소이다 {

	static class Flog{
		Stack<Character> stack;
		boolean flag;
		
		public Flog() {
			super();
			this.stack = new Stack<>();
			flag = false;
		}

		char peek() {
			return stack.peek();
		}
	}
	
	static int ans, end;
	
	public static void main(String[] args) throws NumberFormatException, IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringBuilder sb = new StringBuilder();
		
		int T = Integer.parseInt(br.readLine());
		
		for(int tc = 1 ; tc <= T ; tc++) {
			sb.append("#").append(tc).append(" ");
			
			ArrayList<Flog> flogList = new ArrayList<Flog>();
			
			ans = 0;
			end = 0;
			char[] arr = br.readLine().toCharArray();
			
			for(int i = 0 ; i < arr.length ; i++) {
				
				boolean flag = false;
				
				if(arr[i] == 'c') {
					
					if(end > 0) end--;
					else ans++;
					
					Flog f = new Flog();
					f.stack.add('c');
					flogList.add(f);
					
					flag = true;
				} else if(arr[i] == 'r') {
					for(int j = 0 ; j < flogList.size() ; j++) {
						if(flogList.get(j).peek() == 'c') {
							flogList.get(j).stack.add('r');
							flag = true;
							break;
						}
					}
				} else if(arr[i] == 'o') {
					for(int j = 0 ; j < flogList.size() ; j++) {
						if(flogList.get(j).peek() == 'r') {
							flogList.get(j).stack.add('o');
							flag = true;
							break;
						}
					}
				} else if(arr[i] == 'a') {
					for(int j = 0 ; j < flogList.size() ; j++) {
						if(flogList.get(j).peek() == 'o') {
							flogList.get(j).stack.add('a');
							flag = true;
							break;
						}
					}
				} else if(arr[i] == 'k') {
					for(int j = 0 ; j < flogList.size() ; j++) {
						if(flogList.get(j).peek() == 'a') {
							flogList.get(j).stack.add('k');
							end++;
							flogList.get(j).flag = true;
							flag = true;
							break;
						}
					}
				}
				if(!flag) {
					ans = -1;
					break;
				}
			}
			for(int i = 0 ; i < flogList.size() ; i++) {
				if(!flogList.get(i).flag) {
					ans = -1;
					break;
				}
			}
			sb.append(ans == -1? -1 : ans).append("\n");
		}
		sb.setLength(sb.length() - 1);
		System.out.println(sb);
	}
}