문제
상도시의 차량 번호판 형식이 주어졌을 때, 가능한 차량 번호판의 개수를 구해보자.
- 번호판에 사용할 수 있는 숫자는 0, 1, 2, ..., 8, 9이다.
- 사용할 수 있는 문자는 a, b, c, d, ..., y, z이다.
- 차량 번호판의 형식은 최대 4글자이고, c와 d로 이루어진 문자열로 나타낼 수 있다.
- c는 문자가 위치하는 자리, d는 숫자가 위치하는 자리이다.
- 같은 문자 또는 숫자가 연속해서 2번 나타나면 안 된다.
예를 들어, 형식이 "cd"이면, a1, d4, h5, k4 등이 가능하다. 형식이 "dd"인 경우에 01, 10, 34, 69는 가능하지만, 00, 11, 55, 66은 같은 숫자가 2번 연속해서 불가능하다.
입력
첫째 줄에 차량 번호판의 형식이 주어진다. 형식은 길이가 4보다 작거나 같으며, c와 d로만 이루어져 있다.
출력
첫째 줄에 가능한 차량 번호판의 개수를 출력한다.
구현해야할 조건
숫자와 숫자가 나오면 10 * 9 중복이 안되니까 / 문자와 문자가 나오면 26*25 / 숫자와 문자 10 * 26
/ 문자와 숫자 26 *10 이렇게 구현을 해주면 됩니다. 굳이 전체 조합을 구할 필요도 없습!
code
#include <iostream>
#include <algorithm>
#include <string>
using namespace std;
string s;
int main() {
cin >> s;
int res = 0;
for (int i = 0; i < s.length(); i++) {
if (i == 0) {
if (s[i] == 'd') {
res += 10;
}
else {
res += 26;
}
continue;
}
if (s[i] == s[i - 1]) {
if (s[i] == 'd') {
res *= 9;
}
else {
res *= 25;
}
}
else {
if (s[i] == 'd') {
res *= 10;
}
else {
res *= 26;
}
}
}
cout << res << '\n';
return 0;
}
'PS > BaekJoon' 카테고리의 다른 글
[백준/c++] 배열 돌리기 4 (0) | 2022.03.15 |
---|---|
[백준/c++] 2422 한윤정이 이탈리아에 가서 아이스크림을 사먹는데 (0) | 2022.03.15 |
[백준/c++] 5014 스타트 링크 (0) | 2022.03.15 |
[백준/c++] 10023 적록색약 (0) | 2022.03.15 |
[백준/c++] 6087 레이저 통신 (0) | 2022.03.14 |