leetcode 804. Unique Morse Code Words

International Morse Code defines a standard encoding where each letter is mapped to a series of dots and dashes, as follows: "a" maps to ".-", "b" maps to "-...", "c" maps to "-.-.", and so on.

For convenience, the full table for the 26 letters of the English alphabet is given below:
[".-","-...","-.-.","-..",".","..-.","--.","....","..",".---","-.-",".-..","--","-.","---",".--.","--.-",".-.","...","-","..-","...-",".--","-..-","-.--","--.."]

Now, given a list of words, each word can be written as a concatenation of the Morse code of each letter. For example, "cba" can be written as "-.-..--...", (which is the concatenation "-.-." + "-..." + ".-"). We'll call such a concatenation, the transformation of a word.

Return the number of different transformations among all words we have.

Example:
Input: words = ["gin", "zen", "gig", "msg"]
Output: 2
Explanation: 
The transformation of each word is:
"gin" -> "--...-."
"zen" -> "--...-."
"gig" -> "--...--."
"msg" -> "--...--."

There are 2 different transformations, "--...-." and "--...--.".

Note:

  • The length of words will be at most 100.
  • Each words[i] will have length in range [1, 12].
  • words[i] will only consist of lowercase letters.

這個(gè)題很簡(jiǎn)單。就是通過(guò)建立一個(gè)哈希表昔穴,然后建立一個(gè)集合镰官,把字符串對(duì)應(yīng)的編碼組成字符串,充入集合吗货,統(tǒng)計(jì)集合的長(zhǎng)度就行泳唠。
不過(guò),官網(wǎng)上的Python代碼我覺(jué)得很巧妙宙搬,同時(shí)也讓我發(fā)現(xiàn)自己的python的基礎(chǔ)的不足笨腥。因此我在此寫總結(jié),以此鞏固基礎(chǔ)勇垛。

Python代碼(官網(wǎng)):

class Solution:
    def uniqueMorseRepresentations(self, words: List[str]) -> int:
        Morse = [".-","-...","-.-.","-..",".","..-.","--.","....","..",".---",
                 "-.-",".-..","--","-.","---",".--.","--.-",".-.","...","-","..-",
                 "...-",".--","-..-","-.--","--.."]
        seen = {"".join(Morse[ord(c) - ord('a')] for c in word) for word in words}
        return len(seen)

這個(gè)代碼涉及到的知識(shí)點(diǎn):

  • 集合脖母,在Python中,集合可以用大括號(hào)或set()建立和表示闲孤。
  • 集合生成式谆级,這個(gè)集合生成式和列表生成式比較類似只不過(guò)集合生成式最后得到的是一個(gè)無(wú)序的集合。
  • join()函數(shù)讼积,str.join()中官方文檔的說(shuō)明:
    Return a string which is the concatenation of the strings in iterable. A TypeError will be raised if there are any non-string values in iterable, including bytes objects. The separator between elements is the string providing this method.
    即指的是返回一個(gè)由迭代器里面的字符串連接部分的字符串肥照,并且提供這個(gè)方法的字符串會(huì)作為元素之間的間隔。
  • ord() 勤众,它是chr()的配對(duì)的函數(shù)舆绎,返回字符的對(duì)應(yīng)的ASCII值或Unicode值。

最后的解釋:

  • "".join(Morse[ord(c) - ord('a')] for c in word) 返回單詞里面的每個(gè)字符的對(duì)應(yīng)的ASCII值減去‘a(chǎn)’對(duì)應(yīng)的ASCII值们颜,根據(jù)這個(gè)數(shù)在預(yù)定的Morse列表中選取相應(yīng)的編碼吕朵,組成一個(gè)字符串。
  • A for word in words 就是在words中遍歷掌桩,得到word單詞边锁。
  • len(seen) seen是一個(gè)無(wú)序的集合,可以用len()函數(shù)統(tǒng)計(jì)其長(zhǎng)度波岛。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末茅坛,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌贡蓖,老刑警劉巖曹鸠,帶你破解...
    沈念sama閱讀 221,576評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異斥铺,居然都是意外死亡彻桃,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,515評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門晾蜘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)邻眷,“玉大人,你說(shuō)我怎么就攤上這事剔交∷寥模” “怎么了?”我有些...
    開封第一講書人閱讀 168,017評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵岖常,是天一觀的道長(zhǎng)驯镊。 經(jīng)常有香客問(wèn)我,道長(zhǎng)竭鞍,這世上最難降的妖魔是什么板惑? 我笑而不...
    開封第一講書人閱讀 59,626評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮偎快,結(jié)果婚禮上冯乘,老公的妹妹穿的比我還像新娘。我一直安慰自己滨砍,他們只是感情好往湿,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,625評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著惋戏,像睡著了一般领追。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上响逢,一...
    開封第一講書人閱讀 52,255評(píng)論 1 308
  • 那天绒窑,我揣著相機(jī)與錄音,去河邊找鬼舔亭。 笑死些膨,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的钦铺。 我是一名探鬼主播订雾,決...
    沈念sama閱讀 40,825評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼矛洞!你這毒婦竟也來(lái)了洼哎?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,729評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎噩峦,沒(méi)想到半個(gè)月后锭沟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,271評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡识补,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,363評(píng)論 3 340
  • 正文 我和宋清朗相戀三年族淮,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片凭涂。...
    茶點(diǎn)故事閱讀 40,498評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡祝辣,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出切油,到底是詐尸還是另有隱情较幌,我是刑警寧澤,帶...
    沈念sama閱讀 36,183評(píng)論 5 350
  • 正文 年R本政府宣布白翻,位于F島的核電站,受9級(jí)特大地震影響绢片,放射性物質(zhì)發(fā)生泄漏滤馍。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,867評(píng)論 3 333
  • 文/蒙蒙 一底循、第九天 我趴在偏房一處隱蔽的房頂上張望巢株。 院中可真熱鬧,春花似錦熙涤、人聲如沸阁苞。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,338評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)那槽。三九已至,卻和暖如春等舔,著一層夾襖步出監(jiān)牢的瞬間骚灸,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,458評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工慌植, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留甚牲,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,906評(píng)論 3 376
  • 正文 我出身青樓蝶柿,卻偏偏與公主長(zhǎng)得像丈钙,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子交汤,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,507評(píng)論 2 359