문자열 9단계
2941번. 크로아티아 알파벳
예전에는 운영체제에서 크로아티아 알파벳을 입력할 수가 없었다. 따라서, 다음과 같이 크로아티아 알파벳을 변경해서 입력했다.
크로아티아 알파벳 변경
č c=
ć c-
dž dz=
đ d-
lj lj
nj nj
š s=
ž z=
예를 들어, ljes=njak은 크로아티아 알파벳 6개(lj, e, š, nj, a, k)로 이루어져 있다. 단어가 주어졌을 때, 몇 개의 크로아티아 알파벳으로 이루어져 있는지 출력한다.
dž는 무조건 하나의 알파벳으로 쓰이고, d와 ž가 분리된 것으로 보지 않는다. lj와 nj도 마찬가지이다. 위 목록에 없는 알파벳은 한 글자씩 센다.
첫째 줄에 최대 100글자의 단어가 주어진다. 알파벳 소문자와 '-', '='로만 이루어져 있다.
단어는 크로아티아 알파벳으로 이루어져 있다. 문제 설명의 표에 나와있는 알파벳은 변경된 형태로 입력된다.
입력으로 주어진 단어가 몇 개의 크로아티아 알파벳으로 이루어져 있는지 출력한다.
ljes=njak
6
ddz=z=
3
nljj
3
c=c=
2
dz=ak
3
const fs = require('fs');
const input = fs.readFileSync('/dev/stdin').toString().trim();
// 크로아티아 알파벳을 따로 배열로 만듦
let croatia = ["c=", "c-", "dz=", "d-", "lj", "nj", "s=", "z="];
function solution(input) {
// croatia 배열을 alphabet이라는 변수로 사용
// 배열 원소 하나씩 반복함. 파이썬 같은 느낌!
// "c=" -> "c-" -> "dz=" -> ... 이런 식으로 반복문이 진행됨
for (let alphabet of croatia) {
// 반복문으로 들어온 크로아티아 알파벳으로 split을 하고
// 그 자리를 Q라는 임의의 문자로 채워 넣음
// 크로아티아 알파벳의 길이가 몇 개든 상관없이 Q라는 1개의 문자열로 변환됨!
input = input.split(alphabet).join("Q");
}
// 전부 변환된 문자열의 길이를 return
return input.length;
}
console.log(solution(input));
const fs = require('fs');
const input = fs.readFileSync('/dev/stdin').toString().split('');
let newArr = [];
for(let i = 0; i < input.length; i++){
let newStr = '';
if(input[i + 2] === "=" || input[i + 2] === "-"){
if(input[i] === "d"){
newStr += input[i] + input[i + 1] + input[i + 2];
newArr.push(newStr);
continue;
}
newStr += input[i + 1] + input[i + 2];
newArr.push(newStr);
continue;
} else if(input[i + 1] === "j"){
if(input[i] === "n" || input[i] === "l"){
newStr += input[i] + input[i + 1];
newArr.push(newStr);
continue;
}
}
newArr.push(input[i]);
}
console.log(newArr.length);
나름 예외를 고려해서 코딩해봤는데 고려되지 못한 예외들이 있었다. 그리고 그 것들을 처리하는데 있어서 어려움을 겪었다.
구글링 결과, 무려 백준 공식 답안이 존재하는듯 했다.for(let||const 반복문내부에서사용할이름 of 배열이름)
배열의 요소 하나하나를 반복문의 지표로 사용하는 방법을 사용했고,
그들은 "반복문내부에서사용할이름"이라는 변수로 반복문 내부에서 활용된다.
split()과 join()을 활용해서 크로아티아 문자열을 없애고, 그 자리를 하나의 문자열로 변환했다.
충격적이다..내 코드와 비교하면 너무 간결하고, 지금까지 수도없이 해왔던 메서드들인데 전혀 생각하지 못했다.