質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

1回答

255閲覧

よいアルゴリズムを教えてください。

Null0lluN

総合スコア59

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

1クリップ

投稿2020/02/04 05:59

いつもお世話になっております。

今回ご助力いただきたいのは、以下のアルゴリズム実装についてです。
(ここでは単純化した一例を記述しています。)

以下の数字配列(vector<int> a)があったとします。 1, 2, 2, 1, 2, 1, 1, 2, 1 また、ある数字(0~5(配列内の1の個数); int Num)があったとします。 ここでは仮に3とします。 5C0 ~ 5C5通りの組み合わせで、それぞれ配列中の数字1を4倍します。

私が考えたのは

c++

1//最初に1の場所配列と個数を取得する*1 2int Cnt = 0; 3vector<int> Pos; 4for (int i=0; i< a.size() ; i++) 5{ 6 if(a[i] == 1) 7 { 8 Cnt++; 9 Pos.push_back(i); 10 } 11} 12 13 14//Σ(i=0→Num){(Num)C(i)} = 2^Numを利用し、 15//1 ~ 2^Numまでを二進数化することで、4倍する場所を見つける*2 16long Total = pow(2, Num) 17vector<int> Bin; //二進数を1か0の数値配列と見なす 18for (int i=0; i<Total ; i++) 19{ 20 //二進数化の手法は省略 21 22 //Binが1となるjが4倍されるべきj番目の1 23 //j番目の1はPos[j]に*1で代入されている 24 for (int j=0; j<Total ; j++) 25 { 26 if(Bin[j] == 1) 27 { 28 a[Pos[j]] *= 4; 29 } 30 } 31}

うまくやれば、1と2のように二つに分けなくても
一つのループ文で出来るような気がするのですが、
どのようにネットで調べればよいのか分からなかったので
質問させていただきます。

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ozwk

2020/02/04 06:26 編集

まず「以下のアルゴリズム」が何言ってるかわかりません。 * 「ある数字」(Num)が登場しますが、他で使用されていません。 * 「5C0 ~ 5C5通りの組み合わせ」は何の組み合わせなのか * そもそも5C0 = 5C1 = 1 なので「1 ~ 1通りの組み合わせ」となるが、どういう意味か * 「数字1を4倍」とはなにか? 1を4に置換すること? 実装コードから察してみようとは思いますが、もう少しわかりやすく説明してください
yuki23

2020/02/04 06:15

なぜ、ループを分けてはいけないんでしょうか?(無理なんじゃないかと思いますが)
izmktr

2020/02/04 06:33

2個の場合で考えたら、00, 01, 10, 11の組み合わせになって、1つの数字は2回選択されるんですよね だから、1を4^2で16に置き換えるだけでいい、という結果になりますが… なお、3個なら4回、4個なら8回、5個なら16回選択され、1の部分は4^16の数になります これ、普通のint型ならオーバーフローしてしまいます、なんかおかしいですね?
退会済みユーザー

退会済みユーザー

2020/02/04 09:00

言わんとしていることは理解したものの、最終的に何を入力にして何を出力にしたいのかがソースコードを見ても明確に読みとれません(Bin空のままだし)
guest

回答1

0

c

1for (int i=0; i< a.size(); i++) { 2 if (a[i] == 1) { 3 a[i] *= 4; 4 } 5}

投稿2022/12/03 14:08

ujimushi_sradjp

総合スコア2091

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問