この記事はWeChatの公開アカウント「3分でフロントエンドを学ぶ」から転載したもので、著者はsisterAnです。この記事を転載する場合は、「3分で学ぶフロントエンド」公式アカウントまでご連絡ください。 負でない整数を含む配列が与えられた場合、三角形の 3 辺を形成できる 3 つ組の数を数えることがタスクです。 例1:
知らせ:
解決策: ソート + ダブルポインタ三角形のどの2辺の合計も3番目の辺より大きく、どの2辺の差も3番目の辺より小さいことがわかっています。3辺の長さを小さい方から順にa、b、cとすると、これらの3辺はa + b > cの場合にのみ三角形を形成できます。 解決策: 最初に配列をソートし、次に最長のエッジを固定し、ダブル ポインター メソッドを使用して残りのエッジを決定します。 nums[nums.length - 1]を最長辺nums[k]とする(k = nums.length - 1) nums[i]を最短辺とし、nums[nums.length - 2]を2番目の数nums[j](j = nums.length - 2)とする。 nums[i] + nums[j]がnums[k]より大きいかどうかを判定します。
そして、ji に三角形を形成できる三つ組の数が追加され、j が一つ前の位置 (j--) に移動し、次のラウンドの判定が続行されます。
コード実装:
複雑性分析:
知らせ: Array.prototype.sort() に関しては、ES 仕様では特定のアルゴリズムは指定されていません。バージョン 7.0 より前の V8 エンジンでは、配列の長さが 10 未満の場合、Array.prototype.sort() は挿入ソートを使用し、それ以外の場合はクイックソートを使用します。 クイックソートは安定したソートアルゴリズムではないため、V8 エンジンバージョン 7.0 以降では廃止されました。最悪の場合、時間計算量は O(n2) に低下します。 代わりに、ハイブリッド ソート アルゴリズムである TimSort が使用されます。 この機能アルゴリズムは、もともと Python 言語で使用されていました。厳密に言えば、上記の 10 個のソート アルゴリズムのいずれにも属さず、ハイブリッド ソート アルゴリズムです。 データ量の少ないサブ配列では挿入ソートを使用し、次にマージソートを使用して順序付けられたサブ配列をマージしてソートします。時間の計算量は O(nlogn) です。 リートコード: https://leetcode-cn.com/problems/valid-triangle-number/solution/teng-xun-leetcode611you-xiao-san-jiao-xing-de-ge-s/ |
<<: すべてのビジネスデータを使用しても、AI に完全に入力することはできませんか?この小さなサンプル学習キットをお試しください
>>: 科学者たちは人間のように「考える」ことができる人工知能を開発している
最近、浙江省金華市のある家族の監視ビデオがインターネット上で話題になった。動画の全長は3分15秒。こ...
テクノロジーと通信の急速な進歩により、自動化革命の時代において、アフリカの大規模かつ急成長中の人口は...
今年初めにOpenAIが発表した壮大な傑作「Sora」が、ビデオ関連分野のコンテンツエコロジーを変え...
人工知能 (AI) とモノのインターネット (IoT) の登場により、通信およびインターネット技術業...
導入SOTA 事前トレーニング済みモデルを使用して、転移学習を通じて現実世界のコンピューター ビジョ...
1. はじめに - AI トレーニング データに透かしを追加する理由ディープ ニューラル ネットワー...
広告および推奨システムは、機械学習の最も成熟した応用分野です。では、広告システムや推奨システムでは、...
サンタフェ研究所の教授であり、『人工知能:考える人間のためのガイド』の著者でもあるメラニー・ミッチェ...
[[392106]] AI は広く普及しているにもかかわらず、知識と認識のギャップにより、商業的な導...
10年前に放映されたアメリカのテレビシリーズ「ブラックミラー」の第1話のタイトルは「Be Right...
人生で、私たちは誰でもぼやけた画像に遭遇します。昔は、ぼやけた画像を復元することは不可能でした。PS...
[[348861]]人工知能の時代が本格的に到来しました。私たちの生活のいたるところに見られる人工...
2022年秋、OpenAIがChatGPTをリリースした後、わずか数か月で数千万人のユーザーを獲得し...