2022. 1. 27. 12:23ㆍ알고리즘/백준
문제
Java 예찬론자 김동규와 C++ 옹호가 김동혁은 서로 어떤 프로그래밍 언어가 최고인지 몇 시간동안 토론을 하곤 했다. 동규는 Java가 명확하고 에러가 적은 프로그램을 만든다고 주장했고, 동혁이는 Java는 프로그램이 느리고, 긴 소스 코드를 갖는 점과 제네릭 배열의 인스턴스화의 무능력을 비웃었다.
또, 김동규와 김동혁은 변수 이름을 짓는 방식도 서로 달랐다. Java에서는 변수의 이름이 여러 단어로 이루어져있을 때, 다음과 같은 방법으로 변수명을 짓는다.
첫 단어는 소문자로 쓰고, 다음 단어부터는 첫 문자만 대문자로 쓴다. 또, 모든 단어는 붙여쓴다. 따라서 Java의 변수명은 javaIdentifier, longAndMnemonicIdentifier, name, bAEKJOON과 같은 형태이다.
반면에 C++에서는 변수명에 소문자만 사용한다. 단어와 단어를 구분하기 위해서 밑줄('_')을 이용한다. C++ 변수명은 c_identifier, long_and_mnemonic_identifier, name, b_a_e_k_j_o_o_n과 같은 형태이다.
이 둘의 싸움을 부질없다고 느낀 재원이는 C++형식의 변수명을 Java형식의 변수명으로, 또는 그 반대로 바꿔주는 프로그램을 만들려고 한다. 각 언어의 변수명 형식의 위의 설명을 따라야 한다.
재원이의 프로그램은 가장 먼저 변수명을 입력으로 받은 뒤, 이 변수명이 어떤 언어 형식인지를 알아내야 한다. 그 다음, C++형식이라면 Java형식으로, Java형식이라면 C++형식으로 바꾸면 된다. 만약 C++형식과 Java형식 둘 다 아니라면, 에러를 발생시킨다. 변수명을 변환할 때, 단어의 순서는 유지되어야 한다.
재원이는 프로그램을 만들려고 했으나, 너무 귀찮은 나머지 이를 문제를 읽는 사람의 몫으로 맡겨놨다.
재원이가 만들려고 한 프로그램을 대신 만들어보자.
입력
첫째 줄에 변수명이 주어진다. 영어 알파벳과 밑줄('_')로만 이루어져 있고, 길이는 100을 넘지 않는다.
출력
입력으로 주어진 변수명이 Java형식이면, C++형식으로 출력하고, C++형식이라면 Java형식으로 출력한다. 둘 다 아니라면 "Error!"를 출력한다.
예제 입력 1
long_and_mnemonic_identifier
예제 출력 1
longAndMnemonicIdentifier
문제풀이
import java.io.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
interface Main{
static void main(String[]a) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
String str = br.readLine();
String regex1 = "(?:_([a-z]))", regex2 = "([A-Z])";
if(str.matches(".*[A-Z].*") && str.matches(".*_.*")|| str.matches(".*(_){2,}.*|^([A-Z]|_).*|.*(_)$")||str.equals("")) {
bw.write("Error!");
bw.flush();
} else {
Matcher matcher;
if(str.contains("_")) {
matcher = Pattern.compile(regex1).matcher(str);
while(matcher.find()) {
str = str.replace(matcher.group(), matcher.group(1).toUpperCase());
}
} else if(str.matches(".*([A-Z]).*")) {
matcher = Pattern.compile(regex2).matcher(str);
while(matcher.find()) {
str = str.replace(matcher.group(), "_"+matcher.group().toLowerCase());
}
}
bw.write(str);
bw.flush();
}
}
}
Java 형식 또는 C++ 형식이 아니면 Error!를 출력해야 하는데 그러한 조건은
1. 대문자와 밑줄(_)이 같이 있다.
2. 밑줄이 두 개 이상 있다.
3. 대문자 또는 밑줄로 시작한다.
4. 밑줄로 끝난다.
5. 빈값
이 정도가 있습니다.
이러한 조건을 제외하고 밑줄이 포함되어 있으면 C++ 형식, 대문자가 포함되어 있으면 Java 형식입니다.
C++ 형식을 Java 형식으로 변환할 땐 밑줄+소문자 한 자를 소문자만 그룹핑한 정규식으로 찾아서 대문자로 바꿔주는 식으로 하였고
Java 형식을 C++ 형식으로 변환할 땐 대문자를 그룹핑한 정규식으로 찾아서 밑줄+소문자로 바꿔주는 식으로 하였습니다.
출처 : https://www.acmicpc.net/problem/3613
'알고리즘 > 백준' 카테고리의 다른 글
[백준] 8595번 히든 넘버 Java 문제 풀이 (0) | 2022.02.03 |
---|---|
[백준] 5698번 Tautogram Java 문제 풀이 (0) | 2022.02.03 |
[백준] 6324번 URLs Java 문제 풀이 (0) | 2022.01.24 |
[백준] 1543번 염색체 Java 문제 풀이 (0) | 2022.01.24 |
[백준] 19844번 단어 개수 세기 Java 문제 풀이 (0) | 2022.01.24 |