我正在嘗試用打字稿中風格相似的數字替換字母表中的字母。即字母 I 到 1。我有一個名為 replaceLettersWithNumber 的作業函式,它用所有字母完成這個,但是,我正在努力掌握并實作一個作業解決方案,它從 Hello -> H3llo -> Hell0 延伸到最后, H3ll0。
首先呼叫名為 howManyNumberLookingCharacters 的 Function,回傳的陣列是底部函式中的引數。我是 StackOverflow 的新手,所以如果我可以提供更多資訊,請告訴我。我覺得這很簡單,但是我的大腦不合作!謝謝。
const replacementLetters = ['O', 'I', 'E', 'A', 'T'];
const replacementNumbers = ['0', '1', '3', '4', '7'];
export function howManyNumberLookingCharacters(stringToBeRead: string): {alphabeticalCharacterPosition: number[], alphabeticalCharacter: string[]} {
let alphabeticalCharacterPosition: number[] = [];
let alphabeticalCharacter: string[] = [];
for (let x = 0; x < stringToBeRead.length; x ) {
for (let i = 0; i < replacementLetters.length; i ) {
if (stringToBeRead.toLocaleUpperCase().charAt(x) == replacementLetters[i]) {
alphabeticalCharacterPosition.push(x);
alphabeticalCharacter.push(replacementLetters[i])
}
}
}
return {alphabeticalCharacterPosition, alphabeticalCharacter};
}
export function replaceLettersWithNumber(stringToBeRead: string, alphabeticalCharacterPosition: number[], alphabeticalCharacter: string[]): string[] {
let stringArray: string[] = [];
for (let x = 0; x < alphabeticalCharacter.length; x ) {
var indexInArray = replacementLetters.indexOf(alphabeticalCharacter[x].toString());
stringArray[x] = stringToBeRead.slice(0, alphabeticalCharacterPosition[x]) replacementNumbers[indexInArray] stringToBeRead.slice(alphabeticalCharacterPosition[x] 1);
}
return stringArray;
}
uj5u.com熱心網友回復:
生成組合的最簡單方法是使用遞回。
在可以替換的每個級別,您都可以使用兩個版本呼叫該函式,如下所示:
const replacementNumbers = {
'O': '0',
'I': '1',
'E': '3',
'A': '4',
'T': '7',
};
function replacementCombinations(input: string): string[] {
const uppercase = input.toUpperCase()
const combinations: string[] = []
function r(str: string): void{
if(str.length >= input.length){
combinations.push(str)
return
}
r(str input[str.length])
if(uppercase[str.length] in replacementNumbers)
r(str replacementNumbers[uppercase[str.length]])
}
r('')
return combinations
}
請注意,此代碼假定您正在執行單個字符替換。
轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/414485.html
標籤:
上一篇:如何使用字串定義的函式鍵入常量?
