defvalid(tly,word)
n=word.size
(1...n).each do|i|
pre=word[...i]
suf=word[i...]returntrueif tly.include?(pre)&&(tly.include?(suf)||valid(tly,suf))
endfalseend# @param {String[]} words# @return {String[]}deffind_all_concatenated_words_in_a_dict(words)
tly=words.tally
ans=[]
words.each do|w|
vs=valid(tly,w)
ans<<w if vs
end
ans
end
Hard가 데일리 문제로 나오는 경우도 있군요... 팁 하나 드리자면 concatenated words가 적어도 2개 이상의 더 짧은 단어로 구성된 단어라고 되어 있지만 이 "더 짧은 단어" 중에 서로 다른 게 2개 이상일 필요는 없습니다. 예시로 입력이 ["cat","catcat","catcatcat"]이면 답으로 ["catcat","catcatcat"]을 출력해야 합니다.
댓글 영역
획득법
① NFT 발행
작성한 게시물을 NFT로 발행하면 일주일 동안 사용할 수 있습니다. (최초 1회)
② NFT 구매
다른 이용자의 NFT를 구매하면 한 달 동안 사용할 수 있습니다. (구매 시마다 갱신)
사용법
디시콘에서지갑연결시 바로 사용 가능합니다.