ホームページ バックエンド開発 PHPチュートリアル 数値を変換するための最小ビット反転数

数値を変換するための最小ビット反転数

Sep 12, 2024 am 10:16 AM

Minimum Bit Flips to Convert Number

2220。数値を変換するための最小ビット反転

難易度: 簡単

トピック: ビット操作

数値 x のビット反転は、x のバイナリ表現内のビットを選択し、それを 0 から 1 または 1 から 0 に反転します。

  • たとえば、forx = 7、バイナリ表現は 111 で、任意のビット (表示されていない先行ゼロを含む) を選択して反転できます。右から最初のビットを反転すると 110 が得られ、右から 2 番目のビットを反転すると 101 が得られ、右から 5 番目のビット (先行ゼロ) を反転すると 10111 が得られます。

2 つの整数のスタートとゴールを指定すると、スタートとゴールを変換するためのビット 反転最小数を返します

例 1:

  • 入力: 開始 = 10、目標 = 7
  • 出力: 3
  • 説明: 10 と 7 の 2 進表現は、それぞれ 1010 と 0111 です。 10 を 7 に 3 つのステップで変換できます。
      最初のビットを右から反転します: 1010 -> 1011.
    • 右から 3 番目のビットを反転します: 1011 -> 1111.
    • 右から 4 番目のビットを反転します: 1111 -> 0111.
    • 3 ステップ未満で 10 を 7 に変換することはできないことがわかります。したがって、3 を返します。

例 2:

  • 入力: 開始 = 3、目標 = 4
  • 出力: 3
  • 説明: 3 と 4 の 2 進数表現は、それぞれ 011 と 100 です。 3 つのステップで 3 を 4 に変換できます。
      最初のビットを右から反転します: 011 -> 010.
    • 右から 2 番目のビットを反転します: 010 -> 000.
    • 右から 3 番目のビットを反転します: 000 -> 100.
    • 3 ステップ未満では 3 を 4 に変換できないことがわかります。したがって、3 を返します。

制約:

    0 9

ヒント:

    開始と終了のビットの値が異なる場合は、そのビットを反転する必要があります。
  1. XOR 演算を使用して、ビット フリップが必要なビットを決定することを検討してください。

解決策:

開始と終了の間で何ビット位置が異なるかを決定する必要があります。これは、2 つの数値が異なる各ビット位置に 1 を返す XOR 演算 (^) を使用して簡単に実現できます。

手順:

    スタートとゴールの間で XOR 演算を実行します。結果は、スタートとゴールが異なるすべての位置に 1 が含まれる数字になります。
  1. 結果のバイナリ表現 (つまり、ハミング距離) に 1 がいくつ存在するかを数えます。
  2. 1 の数により、必要なビット 反転の最小数が決まります。
このソリューションを PHP で実装してみましょう:

2220。数値を変換するための最小ビット反転

<?php
/**
 * @param Integer $start
 * @param Integer $goal
 * @return Integer
 */
function minBitFlips($start, $goal) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Test cases
echo minBitFlips(10, 7);  // Output: 3
echo "\n";
echo minBitFlips(3, 4);   // Output: 3
?>
説明:

    ^ (XOR) 演算は、開始と終了の各ビットを比較します。ビットが異なる場合、結果の対応するビットは 1 になります。
  1. 次に、結果内の 1 の数を数えます。これにより、異なるビットの数、つまり必要なビット 反転の数がわかります。
  2. & 1 演算は最後のビットが 1 かどうかをチェックし、>>= 1 は次のビットを処理するために数値を右にシフトします。
時間計算量:

    時間計算量は (O(log N)) です。数値の各ビットをチェックしているため、(N) は開始または終了の大きい方です。最悪の場合、32 ビット整数のすべてのビットをループします (PHP 5.6 はシステムに応じて 32 ビットまたは 64 ビット整数で動作するため)。
出力:

    開始 = 10、目標 = 7 の場合、出力は 3 です。
  • 開始 = 3 および目標 = 4 の場合、出力は 3 です。

連絡先リンク

このシリーズが役立つと思われた場合は、GitHub で

リポジトリ にスターを付けるか、お気に入りのソーシャル ネットワークで投稿を共有することを検討してください。あなたのサポートは私にとって大きな意味を持ちます!

このような役立つコンテンツがさらに必要な場合は、お気軽にフォローしてください:

  • LinkedIn
  • GitHub

以上が数値を変換するための最小ビット反転数の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

ホットトピック

PHPでのオブジェクトリレーショナルマッピング(ORM)パフォーマンスチューニング PHPでのオブジェクトリレーショナルマッピング(ORM)パフォーマンスチューニング Jul 29, 2025 am 05:00 AM

n 1クエリの問題を避け、関連するデータを事前にロードすることにより、データベースクエリの数を減らします。 2.必要なフィールドのみを選択して、メモリと帯域幅を保存するために完全なエンティティをロードしないようにします。 3. DoctrineのセカンダリキャッシュやRedis Cacheの高周波クエリ結果など、キャッシュ戦略を合理的に使用します。 4.エンティティのライフサイクルを最適化し、クリア()を定期的に呼び出してメモリを解放してメモリオーバーフローを防ぎます。 5.データベースインデックスが存在し、生成されたSQLステートメントを分析して、非効率的なクエリを避けます。 6.変更が不要なシナリオで自動変更追跡を無効にし、パフォーマンスを改善するためにアレイまたは軽量モードを使用します。 ORMを正しく使用するには、SQLモニタリング、キャッシュ、バッチ処理、適切な最適化を組み合わせて、開発効率を維持しながらアプリケーションのパフォーマンスを確保する必要があります。

Readonlyプロパティを備えたPHPに不変のオブジェクトを構築します Readonlyプロパティを備えたPHPに不変のオブジェクトを構築します Jul 30, 2025 am 05:40 AM

readonlypropertiesinphp8.2canonlybeassignedonedonedontheconstructoraturatiddeclaration andcannotBemodifiedifiedifiedifiedifiedifiedifiedifiadtivedabilityattthelanguagelele.2.

暗号通貨の計算の取り扱い:PHPにBCMATHが不可欠である理由 暗号通貨の計算の取り扱い:PHPにBCMATHが不可欠である理由 Aug 01, 2025 am 07:48 AM

bcmathisentialforAccuratecurateptocurrencycalcatulationsinphpbecuseating-pointarithmeticincecceptesuncectesubleroundingErrors.1..2 Yieldimimpreciseresults(e.g.、0.300000000000000000000000000precyptowsyptowyprectoyptoyprecyptoyprecyptoyppowsyptowprecyptowprecyptowprecyptowprecyptowprecyptowprecyptowprecyptowpreciseResults)

バリューオブジェクトとしての文字列:ドメイン固有の文字列タイプへの最新のアプローチ バリューオブジェクトとしての文字列:ドメイン固有の文字列タイプへの最新のアプローチ Aug 01, 2025 am 07:48 AM

rawStringsindomain-drivenApplicationsは、ValueObjedStopReventBugsAndimproveTypeTytyのValueObue obue obue obtedsopreated; 1. 1.SustoprimiteObsessionを使用します

PHPのエンジンにおける一定の発現評価を理解する PHPのエンジンにおける一定の発現評価を理解する Jul 29, 2025 am 05:02 AM

phpevaluates constantexpressionsionsatimeTimetoepperpeperformandenableerrordetection.1.constantexpressionevaluationmeansComputingValuesduring during during during duringは、constantslikeliterals、class Conconstants、またはcledefinedconstants.2.phphphse

データスクレイピングとWebオートメーションにPHPを使用します データスクレイピングとWebオートメーションにPHPを使用します Aug 01, 2025 am 07:45 AM

useguzzleforrobustttprequestswithheadersandtimeouts.2.parsehtmleffitywithsymfonydomddomedrawlerusingssseLectors.3.handlejavascript-heavysitesbyintegratingpuppeteerviaphpexec()torenderpages.4.respectrobots.txt、rotedelays.txt、adddelays.txt、adddelays.txt、

PHPの浮動小数点の不正確さの落とし穴をナビゲートします PHPの浮動小数点の不正確さの落とし穴をナビゲートします Jul 29, 2025 am 05:01 AM

浮動小数点数は不正確です。PHPの一般的な問題です。答えは、IEEE754ダブルエシジョン形式を使用していることです。これにより、小数を正確に表現できなくなります。 1.0.1や0.2などの数値は、バイナリの無限ループ10進数であり、コンピューターはエラーを引き起こすために切り捨てられる必要があります。 2。浮動小数点数を比較する場合、abs($ a- $ b)など、==の代わりに許容範囲を使用する必要があります。

パフォーマンスの開梱:PHPスイッチとIF-ELSEに関する真実 パフォーマンスの開梱:PHPスイッチとIF-ELSEに関する真実 Aug 02, 2025 pm 04:34 PM

switchcanbeslyfasterthanif-elsewhencomparingsing liabariableagain stiplescalalarues、特にマネイセイセセソールティグアーズデュートープロシブルオプティイゼーション;

See all articles