バイナリ文字列のすべての順列を生成することで得られるさまざまな数値
###############問題文###
長さ N のバイナリ文字列 str が与えられます。この文字列のすべての順列を検索し、それらを 10 進数値に変換し、すべての一意の 10 進数値を返す必要があります。
###例###
###入力###
リーリー
###出力###
リーリー
「1」の順列はすべて単なる「1」です。したがって、「1」に関連付けられた 10 進数値は 1 と等しくなります。
###入力### リーリー ###出力### リーリーイラスト
「10」の配列は「01」と「10」のみで、それぞれ1と2に相当します。
###入力### リーリー ###出力### リーリーイラスト
「101」の可能な順列はすべて「110」、「101」、「110」、「011」、「101」、「011」です。これらを 10 進数に変換すると、3、5、6 になります。固有の 10 進数。
方法1
最初の方法では、バックトラッキングを使用してバイナリ文字列のすべての順列を取得します。その後、バイナリの順列を 10 進数値に変換し、このセットを使用して一意の 10 進数値を選択します。 pow() メソッドと for ループを使用して 10 進数を 2 進数に変換します。
###アルゴリズム###ステップ 1
- 「getDecimalPermutations()」関数を定義して、結果の 10 進数値を取得します。
ステップ 2
- 「getBinaryPermutations()」関数を実行して、文字列のすべてのバイナリ順列を取得します。さらに、文字列、左右のインデックス、および置換ベクトルが引数として渡されます。
ステップ 2.1
- 「getBinaryPermutations()」関数で、左と右のインデックスが等しい場合、結果の文字列を並べ替えられたリストにプッシュします。
ステップ 2.2
- - 左と右のインデックスが等しくない場合は、for ループを使用して、左のインデックスから右のインデックスまで文字列を繰り返します。
-
-
-
-
-
-
-
-
-
-
###例### リーリー ###出力### リーリー
- 時間計算量
- O(n!)。すべての順列を見つけるためにバックトラッキングを使用するため、「getBinaryPermutations()」関数の時間計算量は「n!」です。 bToD() 関数の時間計算量は O(n) です。
- 空間複雑度
- O(n!)。各文字列には n! 順列があり、それをリストに保存します。
方法 2 -
このアプローチでは、バックトラッキング メソッドの代わりに C の next_permutation() 関数を使用してバイナリ文字列の置換を生成します。また、2進数から10進数への変換方法も変更しました。 ###アルゴリズム###
- 「allNumbers」セットを定義します。
- ステップ 2
- sort() メソッドは、バイナリ文字列を並べ替えるために使用されます。
- ステップ 3
- do-while ループを使用して、文字列の各順列を反復処理します。
- do-while ループで、文字列を引数として渡して bToD() 関数を呼び出し、2 進数を 10 進数に変換します。
ステップ 4.1
- - bToD() 関数で、「currentBase」変数を定義し、1 に初期化します。
-
-
-
-
-
-
示例
#include <iostream> #include <algorithm> #include <set> using namespace std; int bToD(string num){ int decimal_number = 0; // Initializing base value to 1, and it increases by power of 2 in each iteration int currentBase = 1; for (int i = num.length() - 1; i >= 0; i--){ if (num[i] == '1'){ decimal_number += currentBase; } currentBase = currentBase * 2; } return decimal_number; } void getDecimalPermutations(string str){ // create set set<int> allNumbers; // sort the string sort(str.begin(), str.end()); do { // convert binary string to decimal int result = bToD(str); // insert the decimal number to set allNumbers.insert(result); // get the next permutation } while (next_permutation(str.begin(), str.end())); //Print all distinct decimal numbers cout << "All decimal numbers which we can achieve using permutations are " << endl; for (auto num : allNumbers) cout << num << " "; cout << endl; } int main(){ string bString = "101"; getDecimalPermutations(bString); return 0; }
输出
All decimal numbers which we can achieve using permutations are 3 5 6
时间复杂度 - O(n*n!)。这里,next_permutations() 需要 O(n) 时间来找到一个排列,并且我们正在找到总共 n!排列。
空间复杂度 - O(n!),因为我们将所有排列存储在列表中。
结论
我们学习了不同的方法来获取通过给定二进制字符串的所有排列获得的唯一十进制值。在第一种方法中,我们使用了回溯;在第二种方法中,我们使用了 next_permutation() 方法。
第二种方法的代码更清晰,但需要更多的时间和复杂性。
以上がバイナリ文字列のすべての順列を生成することで得られるさまざまな数値の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック

この記事では、C標準テンプレートライブラリ(STL)について説明し、そのコアコンポーネント(コンテナ、イテレーター、アルゴリズム、およびファンクター)に焦点を当てています。 これらが一般的なプログラミングを有効にし、コード効率を向上させ、読みやすさを改善する方法を詳述しています。

この記事では、cの効率的なSTLアルゴリズムの使用について詳しく説明しています。 データ構造の選択(ベクトル対リスト)、アルゴリズムの複雑さ分析(STD :: STD :: STD :: PARTIAL_SORTなど)、イテレーターの使用、および並列実行を強調しています。 のような一般的な落とし穴

この記事では、Cでの効果的な例外処理、トライ、キャッチ、スローメカニックをカバーしています。 RAIIなどのベストプラクティス、不必要なキャッチブロックを避け、ログの例外をロギングすることを強調しています。 この記事では、パフォーマンスについても説明しています

この記事では、不必要なコピーを回避することにより、パフォーマンスを向上させるために、CのMove Semanticsを使用することについて説明します。 STD :: MOVEを使用して、移動コンストラクターと割り当てオペレーターの実装をカバーし、効果的なAPPLの重要なシナリオと落とし穴を識別します

C 20の範囲は、表現力、複合性、効率を伴うデータ操作を強化します。複雑な変換を簡素化し、既存のコードベースに統合して、パフォーマンスと保守性を向上させます。

この記事では、Cでの動的発送、そのパフォーマンスコスト、および最適化戦略について説明します。動的ディスパッチがパフォーマンスに影響を与え、静的ディスパッチと比較するシナリオを強調し、パフォーマンスとパフォーマンスのトレードオフを強調します

記事では、移動セマンティクス、完璧な転送、リソース管理のためのcでのr値参照の効果的な使用について説明し、ベストプラクティスとパフォーマンスの改善を強調しています。(159文字)

Cメモリ管理は、新しい、削除、およびスマートポインターを使用します。この記事では、マニュアルと自動化された管理と、スマートポインターがメモリリークを防ぐ方法について説明します。
