0-9 숫자의 잘못된 영어 표현을 포함하는 비어 있지 않은 문자열이 있다고 가정하고 숫자를 오름차순으로 출력합니다. 몇 가지 속성이 있습니다 -
- 입력은 유효하며 원래 숫자로 변환될 수 있습니다. 즉, "abc" 또는 "zero"와 같은 잘못된 입력은 허용되지 않습니다.
- 입력 길이가 50,000 미만입니다.
따라서 입력이 "fviefuro"와 같으면 출력은 45가 됩니다.
이 문제를 해결하기 위해 다음 단계를 따릅니다. −
- nums :=0에서 9까지의 영문자로 된 숫자를 포함하는 배열
- 크기가 10인 배열 하나 만들기
- ans :=빈 문자열입니다. 및 n :=문자열의 크기입니다.
- 0 ~ n – 1 범위의 i에 대해
- s[i] ='z'이면 count[0]을 1만큼 증가
- s[i] ='w'이면 count[2]를 1만큼 증가
- s[i] ='g'이면 count[8]을 1만큼 증가
- s[i] ='x'이면 count[6]을 1만큼 증가
- s[i] ='v'이면 count[5]를 1만큼 증가
- s[i] ='o'이면 count[1]을 1만큼 증가
- s[i] ='s'이면 count[7]을 1만큼 증가
- s[i] ='f'이면 count[4]를 1만큼 증가
- s[i] ='h'이면 count[3]을 1 증가시킵니다.
- s[i] ='i'이면 count[9]를 1만큼 증가
- 카운트[7] :=카운트[7] – 카운트[6]
- count[5] :=count[5] – 카운트[7]
- count[4] :=count[4] – 카운트[5]
- count[1] :=count[1] – (count[2] + count[4] + count[0])
- count[3] :=count[3] – 카운트[8]
- count[9] :=count[9] – (count[5] + count[6] + count[8])
- 0에서 9 사이의 i에 대해
- 범위 0에 있는 j의 경우 [i]
- ans :=as + (i + '0')의 문자
- 범위 0에 있는 j의 경우 [i]
- 반환
예시(C++)
이해를 돕기 위해 다음 구현을 살펴보겠습니다. −
#include <bits/stdc++.h> using namespace std; class Solution { public: string originalDigits(string s) { string nums[]= {"zero", "one", "two", "three", "four", "five", "six", "seven","eight", "nine"}; vector <int> cnt(10); string ans = ""; int n = s.size(); for(int i = 0; i < n; i++){ if(s[i] == 'z')cnt[0]++; if(s[i] == 'w') cnt[2]++; if(s[i] == 'g')cnt[8]++; if(s[i] == 'x')cnt[6]++; if(s[i] == 'v')cnt[5]++; if(s[i] == 'o')cnt[1]++; if(s[i] == 's')cnt[7]++; if(s[i] == 'f')cnt[4]++; if(s[i] == 'h')cnt[3]++; if(s[i] == 'i') cnt[9]++; } cnt[7] -= cnt[6]; cnt[5] -= cnt[7]; cnt[4] -= cnt[5]; cnt[1] -= (cnt[2] + cnt[4] + cnt[0]); cnt[3] -= cnt[8]; cnt[9] -= (cnt[5] + cnt[6] + cnt[8]); for(int i = 0; i < 10; i++){ for(int j = 0; j < cnt[i]; j++){ ans += (char)(i + '0'); } } return ans; } }; main(){ Solution ob; cout << ob.originalDigits("fviefuro"); }
입력
"fviefuro"
출력
"45"