c++で組合せを生成する
2023-09-22 08:34:05
質問
私はc++を使用して組み合わせを生成するためのソースコードを検索しています。このためのいくつかの高度なコードを見つけましたが、それは特定の数の事前定義されたデータにのみ適しています。どなたか、組合せを生成するためのヒントというか、アイデアを教えていただけませんか?例として、集合S = { 1, 2, 3, ..., n}からr= 2を選ぶとする。入力は次のようになる。
n
となり
r
.この場合、プログラムは5 2 outputs 1 2, 1 3, などのように長さ2の配列を生成することになります。アルゴリズムの組み立てに苦労しました。これを考えるのに1ヶ月かかりました。
どのように解決するのですか?
簡単な方法として
std::next_permutation
:
#include <iostream>
#include <algorithm>
#include <vector>
int main() {
int n, r;
std::cin >> n;
std::cin >> r;
std::vector<bool> v(n);
std::fill(v.end() - r, v.end(), true);
do {
for (int i = 0; i < n; ++i) {
if (v[i]) {
std::cout << (i + 1) << " ";
}
}
std::cout << "\n";
} while (std::next_permutation(v.begin(), v.end()));
return 0;
}
または、より簡単な順序で結果を出力する若干のバリエーションがあります。
#include <iostream>
#include <algorithm>
#include <vector>
int main() {
int n, r;
std::cin >> n;
std::cin >> r;
std::vector<bool> v(n);
std::fill(v.begin(), v.begin() + r, true);
do {
for (int i = 0; i < n; ++i) {
if (v[i]) {
std::cout << (i + 1) << " ";
}
}
std::cout << "\n";
} while (std::prev_permutation(v.begin(), v.end()));
return 0;
}
ちょっとだけ説明。
これは、"選択配列"を作成することで動作します(
v
) を作成し、そこに
r
セレクタを配置した後、これらのセレクタのすべての並べ換えを作成し、対応するセットメンバが現在の
v
. これが役に立つことを願っています。
関連
-
[解決済み】Visual C++で "Debug Assertion failed "の原因となる行を見つける。
-
[解決済み】ファイルから整数を読み込んで配列に格納する C++ 【クローズド
-
[解決済み】C++ - ステートメントがオーバーロードされた関数のアドレスを解決できない。
-
[解決済み】Eclipse IDEでC++エラー「nullptrはこのスコープで宣言されていません」が発生する件
-
[解決済み】'std::cout'への未定義の参照
-
[解決済み] nからk個の要素の組み合わせをすべて返すアルゴリズム
-
[解決済み] リストの要素のすべての可能な組み合わせを得るには?
-
[解決済み] なぜこのプログラムは3つのC++コンパイラで誤って拒否されるのですか?
-
[解決済み】与えられた文字列のすべての並べ換えを生成する
-
[解決済み】リストのリストのすべての組み合わせ
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】 unsigned int vs. size_t
-
[解決済み】C++コンパイルタイムエラー:数値定数の前に期待される識別子
-
[解決済み] クラスにデフォルトコンストラクタが存在しない。
-
[解決済み】「Expected '(' for function-style cast or type construction」エラーの意味とは?
-
[解決済み】Visual C++で "Debug Assertion failed "の原因となる行を見つける。
-
[解決済み] [Solved] インクルードファイルが開けません。'stdio.h' - Visual Studio Community 2017 - C++ Error
-
[解決済み】CMakeエラー at CMakeLists.txt:30 (project)。CMAKE_C_COMPILER が見つかりませんでした。
-
[解決済み】クラスのコンストラクタへの未定義参照、.cppファイルの修正も含む
-
[解決済み】C++ - ステートメントがオーバーロードされた関数のアドレスを解決できない。
-
[解決済み] nからk個の要素の組み合わせをすべて返すアルゴリズム