インタビュアー: 「最後にアルゴリズムを書いてください。単一のリンクリストを使用して加算を実行してみましょう...」

インタビュアー: 「最後にアルゴリズムを書いてください。単一のリンクリストを使用して加算を実行してみましょう...」

[[286163]]

質問: 空でない 2 つのリンク リストが与えられた場合、2 つの負でない整数を表します。それらの間では、それぞれの数字が逆の順序で格納され、各ノードには 1 つの数字しか格納できません。 2 つのリンク リストを加算し、その合計を表す新しいリンク リストを返します。

例: 342 + 465 = 807

2 つの数値を加算する問題は、最も単純な数学的加算演算を伴いますが、リンク リストに基づいているため、リンク リストの処理に難しさがあります。

加算演算では、各ビットを加算するだけでなく、桁上げの状況も考慮する必要があります。この問題では、連結リストの各ノードに数字が格納され、自然数に基づいて逆順に格納されます。つまり、チェーンの先頭から末尾まで、低い値から高い値への順序が維持されます。つまり、桁上げの方向は単一の連結リストの方向と一致します。

単方向リンクリストの特性上、先行ノードが存在せず、戻ることはできません。この問題のシナリオでは、チェーンの先頭 (低い位置) からチェーンの終わり (高い位置) まで処理する while ループが 1 つだけ必要で、問題を解決できます。ただし、繰り上がり状況の処理には注意が必要です。計算後、各ノードは余りを 10 で割って保存する必要があります。余りは、計算に参加するために次のノードに繰り上がる必要があり、これは単一のリンク リストの処理の考え方と一致しています。

次に、いくつかの変数、各ビット操作後のキャリーを記録するキャリー、および 2 つのリンク リストの加算操作後のリンク リスト ノードを記録するダミー ノードが必要になります。


最長のリンクリストの最後のノードを処理するときは、キャリーに対して追加の処理を実行する必要があります。キャリーが 0 でない場合は、キャリーがより高い位置まで続くことを意味し、キャリーを格納するための新しいノードを作成する必要があります。

ここでの説明は明確です。コードに直接進みましょう。

  1. パブリックリストノード addTwoNumbers(リストノード l1、リストノード l2) {
  2. // 計算結果を格納するダミーノード
  3. ListNode ダミー = 新しい ListNode(0);
  4. リストノード p = l1、q = l2、curr = ダミー;
  5. // 繰り上がりのデフォルトは 0 です
  6. 整数キャリー = 0;
  7. // ループに入り、p と q のリンクリストポインタが両方とも末尾に到達したら終了します
  8. (p != null || q != null ) の場合 {
  9. int x = (p != null ) ? p.val : 0;
  10. int y = (q != null ) ? q.val : 0;
  11. // キャリーが操作に参加する
  12. 整数 合計= 繰り上がり + x + y;
  13. // キャリーを計算する
  14. 繰り上がり =合計/ 10;
  15. //計算された数字の値を格納するための新しいノードを構築します
  16. curr.next = 新しいListNode(合計% 10 );
  17. curr = curr.next ;
  18. (p != null )の場合
  19. p = p.next ;
  20. (q != null の場合
  21. q = q.next ;
  22. }
  23. // 数値の最上位桁の末尾の繰り上がりを処理する
  24. (キャリー>0)の場合{
  25. curr.next = 新しいListNode(carry);
  26. }
  27. dummy.nextを返します
  28. }

ここで、p と q は、ループの基礎となる 2 つのリンク リスト l1 と l2 のノードをそれぞれ格納するために使用されます。ループを終了する条件は、両方のリンク リストが末尾に到達していることです。

各ループでは、各ノードの値が処理され、繰り上がり値が加算されます。演算後、残りの値は新しいノードに格納され、新しい繰り上がり値は保存用にキャリーに格納されます。

最後に、両方のリンク リストが処理された後、最上位ビットを繰り上げる必要があるかどうか (繰り上げ > 0) を判断する必要があることに注意してください。必要に応じて、繰り上がり値を格納するための新しいリンク リスト ノードを作成します。

リンク リストを使用して加算演算を実行するこの問題の説明はこれで終わりですが、これにはいくつかのバリエーションもあります。

リンク リストが数字をビットごとに逆順で格納しない場合はどうなるでしょうか。順順で格納した場合はどうなるでしょうか。

例えば:

1 → 2 → 3

+ 3 → 2 → 1

=> 123 + 321 = ?

[この記事は51CTOコラムニスト「張楊」によるオリジナル記事です。転載の許可を得るにはWeChat公式アカウントを通じて著者に連絡してください]

この著者の他の記事を読むにはここをクリックしてください

<<:  ニューラルネットワークの過剰適合を避ける 5 つのテクニック

>>:  2020 年にチャットボットはどこに向かうのでしょうか?

ブログ    
ブログ    
ブログ    

推薦する

自動運転トラックの普及が加速しているが、実用化にはどれくらいの時間がかかるのだろうか。

iResearch Instituteが発表したレポートによると、2021年の中国の幹線物流大型ト...

高精度地図のデータの問題についてお話ししましょう。地図以外の認識の落とし穴は何でしょうか?

この記事は、Heart of Autonomous Driving の公開アカウントから許可を得て転...

...

...

...

CMU ロボット犬が逆さまに階段を降りる!オープンソースとしてリリース

正直に言うと、私はロボット犬の技をたくさん見てきました -しかし、私は今日も驚きました。 CMU の...

ロボットにあなたのことをもっと理解させるにはどうすればいいでしょうか?

[[361286]]自然言語処理技術は人工知能技術の重要な分野です。自然言語処理技術自体が成熟する...

ビッグモデルの「錯覚」、この記事を読んでください

ビッグモデルの「幻想」がついに体系的にレビューされました! 49 ページの記事では、幻覚の定義、分類...

監督が消えた! Midjourney+Miaoyaカメラ+Gen2の新ゲームプレイ:10元でMuskユニバースを作成し、ワンクリックでビデオを作成します

生成 AI の爆発的な増加により、無限の可能性がもたらされました。最近、国内ではミャオヤカメラがイン...

販売禁止の影で、国産GPGPUがその穴を埋めることはできるのか?

今年初め、ChatGPTはAIアプリケーションの開発を刺激する火花のようなもので、AI業界は開発の急...

...

人工知能、ロボット工学、そして道徳的リスク

人工知能は、産業用ロボットやロボットプロセス自動化 (RPA) における新たなアプリケーションを推進...

2019年最後の月に、知っておくべき6つの最新の剪定テクニックをご紹介します

剪定技術についてどれくらいご存知ですか? 2019年に6つの論文で紹介された最新の剪定方法をまとめた...

ファーウェイがGood Vision Cloud Serviceを正式に開始、包括的なマシンビジョンの時代を先導

人工知能技術の台頭とエッジデバイスのコンピューティング能力の向上により、マシンビジョンの応用シナリオ...

プログラミングの達人セスブリングがマリオカートで勝つためのAIソフトウェアを開発

海外のゲームプログラミングの達人、SethBling氏が新しいガジェットをリリースした。同氏は以前、...