프로그래밍/알고리즘
프로그래머스/위클리 챌린지/모음 사전
Doublsb
2021. 8. 31. 22:00
https://programmers.co.kr/learn/courses/30/lessons/84512
풀이
- A, E, I, O, U만을 사용해 만들 수 있는 길이 5 이하의 모든 단어가 수록된 사전
- 사전 첫 단어는 A, 그 다음이 AA, 마지막이 UUUUU
- 단어 하나가 주어지면 사전의 몇 번째 단어인지 return
- "A"는 "10000"으로 생각하면 편하다
- 사전은 이 숫자들을 오름차순으로 정렬했다고 보면 된다
- 예를 들어, A => 10000, AA => 11000, UEI => 52300이다.
- 10000부터 55555까지 모든 가능성을 돌리면서, 주어진 단어가 발견되면 해당 횟수를 리턴하면 되겠다
C#
using System;
using System.Linq;
public class Solution {
public int solution(string word) {
int counter = 0;
string goal = convert(word);
for(int i=10000; i<=55555; i++)
{
if(isValid(i.ToString()))
{
counter++;
if(goal == i.ToString()) return counter;
}
}
return 0;
}
private bool isValid(string str){
int zeroIndex = str.IndexOf('0');
if(zeroIndex != -1
&& str.Substring(zeroIndex).Any(e => e != '0'))
{
return false;
}
else if(str.Any(e => NonValid.Contains(e))){
return false;
}
else return true;
}
private readonly char[] NonValid
= new char[] { '6', '7', '8', '9' };
private string convert(string str){
var result = "";
for(int i=0; i<5; i++){
if(str.Length - 1 >= i){
switch(str[i]){
case 'A':
result += '1';
break;
case 'E':
result += '2';
break;
case 'I':
result += '3';
break;
case 'O':
result += '4';
break;
case 'U':
result += '5';
break;
}
}
else result += '0';
}
return result;
}
}
결과
100.0 / 100.0
피드백
더 단순하게 경우의 수를 곱하는 형태의 수학 문제처럼 풀 수도 있을 것 같은데, 그 방법을 잘 모르겠음.
나는 그냥 컴퓨터한테 맡기기로 했다 ^w^...
반응형