国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

每日一道算法題 - LetterChanges(easy-4)

mo0n1andin / 3579人閱讀

摘要:更多的小算法練習,可以查看我的文章。規則使用語言,使用函數獲取傳遞的參數并使用以下算法對其進行修改。將字符串中的每個字母替換為字母表后面的字母即變為,變為。然后將這個新字符串,,,,中的每個元音大寫,并最終返回此修改后的字符串。

雖然都是很簡單的算法,每個都只需5分鐘左右,但寫起來總會遇到不同的小問題,希望大家能跟我一起每天進步一點點。
更多的小算法練習,可以查看我的文章。

規則

Using the JavaScript language, have the function LetterChanges(str) take the str parameter being passed and modify it using the following algorithm. Replace every letter in the string with the letter following it in the alphabet (ie. c becomes d, z becomes a). Then capitalize every vowel in this new string (a, e, i, o, u) and finally return this modified string.

使用JavaScript語言,使用函數LetterChanges(str)獲取傳遞的str參數并使用以下算法對其進行修改。
將字符串中的每個字母替換為字母表后面的字母(即 c變為d,z變為a)。
然后將這個新字符串(a,e,i,o,u)中的每個元音大寫,并最終返回此修改后的字符串。

測試用例
Input:"hello*3"
Output:"Ifmmp*3"


Input:"fun times!"
Output:"gvO Ujnft!"

Input:"I love Code Z!"
Output:"J mpwf DpEf A!"
my code
function LetterChanges(str) {
    var strArr = ["a", "e", "i", "o", "u"]
    var newStr = ""
  
    for(var i=0;i= 97) {
          asciiCode = asciiCode === 122 ? 97 : asciiCode + 1
          tempStr =  String.fromCharCode(asciiCode)
      }else if(asciiCode <= 90 && asciiCode >= 65) {
          asciiCode = asciiCode === 90 ? 65 : asciiCode + 1
          tempStr =  String.fromCharCode(asciiCode)
      }
  
      if(strArr.indexOf(tempStr) !== -1) {
          tempStr = tempStr.toUpperCase()
      }
      newStr += tempStr
    }
   
    return newStr; 
}
other code
function LetterChanges(str) { 
    str = str.replace(/[a-zA-Z]/g, function(ch) {
        if (ch === "z") return "a";
        else if (ch === "Z") return "A";
        else return String.fromCharCode(ch.charCodeAt(0) + 1);
    });
   
    return str.replace(/[aeiou]/g, function(ch) {
        return ch.toUpperCase();
    });
}
思路

方法1: 使用ASCII碼去判斷,a-z(97,122)之間;A-Z(65,90)之間

方法2:使用正則去匹配,特殊情況如"z"和"Z",返回對應的值

知識點

charCodeAt(),獲取字符串的ASCII碼

String.fromCharCode(), 把ASCII碼轉換成字符串

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/96036.html

相關文章

  • 每日一道算法 - 反轉字符串(easy-3)

    摘要:規則使用語言,讓函數獲取傳遞的參數,并以相反的順序返回字符串。測試用例思路方法通過把字符串轉換成數組,并使用數組的反轉數組,然后使用重新拼接成字符串方法向后循環字符串或字符數組以生成新字符串 雖然都是很簡單的算法,每個都只需5分鐘左右,但寫起來總會遇到不同的小問題,希望大家能跟我一起每天進步一點點。更多的小算法練習,可以查看我的文章。 規則 Using the JavaScript l...

    xfee 評論0 收藏0
  • 每日一道算法 - LongestWord(easy-1)

    摘要:規則使用語言,讓函數獲取傳遞的參數并返回字符串中的最大單詞。忽略字符串中標點符號并假設不會為空。測試用例思路通過過濾字符串,并把字符串根據空格符轉換成字符串數組通過循環把獲取字符串數組中的長度最長的字符串 雖然都是很簡單的算法,每個都只需5分鐘左右,但寫起來總會遇到不同的小問題,希望大家能跟我一起每天進步一點點。更多的小算法練習,可以查看我的文章。 規則 Using the JavaS...

    plokmju88 評論0 收藏0
  • 每日一道算法

    摘要:遇到的坑剛拿到這道題就直接做了這樣的判斷,可是萬一是這個判斷就是錯誤的了。思路二上述算法遍歷了兩次鏈表,還額外申請了一個數組空間,效率不高,不如直接就地反轉鏈表,更改每個節點自身的指針。 2018.10.14 來源:劍指offer 題目:反轉鏈表 輸入一個鏈表,反轉鏈表后,輸出新鏈表的表頭。思路一:把所有鏈表內容都輸入到一個數組,再次遍歷鏈表,得到數組反轉后的值,最后輸出原來的head...

    The question 評論0 收藏0
  • 每日一道算法--二維數組中的查找--python

    摘要:題目描述代碼思路思路一按行執行二分查找,只要該行的第一個元素小于目標,就對該行二分查找。思路二從數組的左下角開始查找,如果當前值小于目標,就向右,即如果當前值大于目標,就向上,即。【題目描述】 showImg(https://user-gold-cdn.xitu.io/2019/5/22/16addf094e0320ca); 【代碼思路】 思路一:按行執行二分查找,只要該行的第一個元素小于目...

    番茄西紅柿 評論0 收藏0
  • 每日一道算法--二維數組中的查找--python

    摘要:題目描述代碼思路思路一按行執行二分查找,只要該行的第一個元素小于目標,就對該行二分查找。思路二從數組的左下角開始查找,如果當前值小于目標,就向右,即如果當前值大于目標,就向上,即?!绢}目描述】 showImg(https://user-gold-cdn.xitu.io/2019/5/22/16addf094e0320ca); 【代碼思路】 思路一:按行執行二分查找,只要該行的第一個元素小于目...

    luck 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<