例えばですが、
const a = "I like an apple";
const b = "I drank apple juice";
変数の中身を知らない状態で a と b を比較したときに同じ単語(apple)が含まれているので、true を返す事は出来ますでしょうか?
よろしくお願いします。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
I も両方に含まれてますが無視するんでしょうか?
2022/11/29 20:47
説明不足ですみません。2文字以上の文字が一致したときのみtrueを返したいです
回答2件
0
ベストアンサー
考え方
- 英文のみ(日本語には対応しない)という前提でのコードです。
- 両方の英文を全て小文字化 → 記号を削除 → スペースで分割して配列化。
- 一方の配列(例
arr1
)の中の単語を一つずつ繰り返し処理で、もう一方の配列(例arr2
)の中の何番目に存在するかインデックス番号を取得する。.indexOf()
は要素が存在したらそのインデックス番号を戻し、なければ-1
を戻す。- つまり
0
以上の数字が戻されたら、存在するということなので、true
。 -1
が戻されたら存在しないということなので、false
。
コード例
- 動作確認用サンプル:https://jsfiddle.net/0a5bedsk/2/
javascript
1function hasSameWord(str1, str2) { 2 // 文字列を全部小文字化し → 「"」「'」「.」「,」「?」「!」の記号を取り除き → スペースで分割して配列に格納 3 const arr1 = str1.toLowerCase().replace(/["'.,!?]/g, '').split(' '); 4 const arr2 = str2.toLowerCase().replace(/["'.,!?]/g, '').split(' '); 5 6 // arr1の単語をarr2と比較 7 for (const word of arr1) { 8 // 同じ単語が存在したら、trueを戻し、ここで関数を終了する(以降は実行されない) 9 if (arr2.indexOf(word) >= 0) { 10 return true; 11 } 12 } 13 14 // 同じ単語が存在しなかったら、falseを戻す 15 return false; 16} 17 18const a = 'I like an apple.'; 19const b = 'You drank "Apple juice".'; 20console.log(hasSameWord(a, b)); //true 21 22const c = 'I love the dish, which my mom made.'; 23const d = 'The Dish Washer is awesome!'; 24console.log(hasSameWord(c, d)); //true 25 26const e = 'Tertail is a good service.'; 27const f = 'I\'m feeling great'; 28console.log(hasSameWord(e, f)); // false 29
投稿2022/11/29 10:51
編集2022/11/29 11:52総合スコア2316
0
とりあえず細かい例外処理はすっとばせばこんな感じでも
javascript
1const a = "I like an apple"; 2const b = "I drank apple juice"; 3const c = "You drank orange juice"; 4 5const chk=(x,y)=>x.split(" ").some(x=>y.split(" ").includes(x)); 6console.log(chk(a,b)); // true 7console.log(chk(a,c)); // false
投稿2022/11/30 02:40
総合スコア116724
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。