Re: [閒聊] 每日LeetCode

作者: AyuniD (アユニ.D)   2023-01-02 13:59:59
※ 引述《Rushia (みけねこ的鼻屎)》之銘言:
: 520. Detect Capital
: 給你一個字串,判斷他是否符合下列情況:
: (1)全部字母都大寫
: (2)全部字母都小寫
: (3)首字大寫其他字母小寫
: 若符合就返回true,否則返回false,測資只會輸入大寫和小寫字母。
思考:
因為這題不會有空格,所以只需要考慮一個字的情況。
按照題目所說,大寫字母只會有 0 個、1 個或全部都是。
所以我就從數數著手了。
程式碼:
class Solution:
def detectCapitalUse(self, word: str) -> bool:
return len((l := [(i, ch) for i, ch in enumerate(word) \
if ch.isupper()])) in [0, 1, len(word)] \
and (l[0][0] == 0 if l else True)
(為了閱讀方便才換行的)
附註:
因為在一個大寫字母的情況下要考慮到它是不是在字首,
所以我用 enumerate 去遍歷而不是直接對 word 本身做,
這樣我就可以在後面去看大寫字元的 index。
後面的三元運算子是要確保有 l 這個 list 存在,
因為沒有大寫字母的話會是空的,這時候我們就用 True 代替。
作者: pandix (麵包屌)   2023-01-02 14:22:00
大師return word[1:] == word[1:].lower() or word.isupper()討論區看到的 這也好強==

Links booklink

Contact Us: admin [ a t ] ucptt.com