- ベストアンサー
2つの配列要素を比較して、一致しない要素を別配列にしたい
- みんなの回答 (1)
- 専門家の回答
質問者が選んだベストアンサー
Perl付属ドキュメントperlfaq4の “How do I compute the difference of two arrays? How do I compute the intersection of two arrays?” が参考になるかと。
関連するQ&A
- Action Script 2.0 配列の比較
複数のチェックボックスの値(true,false)を取得して配列に格納し、別の配列(A、B、C)と比較をし一致項目の多い配列を決める処理を実現したくて四苦八苦しておりました。 更に細かく書かせて頂くと 1.チェックボックスは12個 2.複数選択可 3.チェックが5個以下の場合は、ボタンを押しても動かないようにする 4.12個全ての値を取得しtrueの値のみの番号を別の配列に入れる チェックボックスの値の取得し、配列に入れるところまでは大丈夫なんですが、その後の「比較して一致項目の多いものを選択」という作業で詰まってました。 例として・・・・ アンサー配列[1,2,3,4,6,8]があった場合 一致項目が多いもの A配列[1,4,5,6,7,8] この場合4個同じ B配列[1,2,3,4,5,6,7,8] この場合6個同じ C配列[1,2,8,9,10,11] この場合3個同じ 結果として ○完全一致の場合の処理 ○一致項目が多い場合の処理 ○3つとも同じ場合の処理 この場合は、B配列に決定という流れを考えてました。 どなたかお知恵を授けて頂ければと思います。
- ベストアンサー
- Flash
- 配列から別の配列の要素を削除する方法
ある配列array_aに、100件の文字列要素が格納されています。 別の配列array_bには、80件の文字列要素が格納されています。 array_aの要素、array_bの要素共に重複するものはありません。 array_b中に存在する要素はすべてarray_a中にも存在します。 array_aにあり、array_bにはない要素で構成されたarray_cの作り方を教えてください。 例えば $array_a=array("a","b","c","d","e","f","g"); $array_b=array("e","b","d"); なら、 $array_c=array("a","c","f","g") になります。 配列array_aとarray_bは、 $array_b=array("b","b","d"); であったり、 $array_a=array("a","a","b","c","d","e","f","g"); といった「重複する要素を含むパターン」はありません。要素はすべてユニークです。 よろしくお願いいたします。
- ベストアンサー
- PHP
- perlで配列の要素が空なのを知るには?
教えてください。 例えば、perlの次の様な要素が3つある配列で、 @t = ('A',,'C'); 2要素目が空で有ることを判別したいのですが、どうしたら良いでしょうか?
- ベストアンサー
- Perl
- 配列の要素追加について
配列Aがあり、その配列に別の要素を加えた配列Bを作成するためにはどのようにすればよいのでしょうか? Aをコピーしたものに要素を一つ加えてと考えたのですが。。。 つまり char[] a = {'a', 'b', 'c'}; char ch = 'd'; とあったときに、aにchを加えて char[] b = {'a', 'b', 'c', 'd'}; を作成したいです。 よろしくお願い致します。
- ベストアンサー
- Java
- 一致する要素が格納されている添え字番号を返す
例えばある配列内に @moji = (ak, df, gc); などという値でも文字でもが格納されていたとして、 $x = "ak"; といったある変数に格納されている値・文字(この場合はak)と一致する要素が配列@mojiに格納されていた場合に、その格納されている要素の添え字番号(配列の添え字番号)を返すような関数はないでしょうか? イメージとして $res = mch($x); とすると、0が返されて$resに格納されるというものです。 ちなみにRという言語では > a <- c("ljj", "B0", "op199") # 変数aに3つの文字列要素を代入する > res <- which(a == "op199") # which()は引数に指定された論理に一致する要素番号を返す > res # aについて,a == "op199"がTRUEとなるのは要素番号3であるから,3を返す [1] 3 というものがあるのですが、これと同じような関数が欲しいのです(泣)
- ベストアンサー
- Perl
- 配列の重複削除について
配列の重複削除について教えて下さい。 普通の重複チェックとは違い、3つの配列 それぞれに値があり、添え字が0から同じ ように始まり、3つの配列が全て同じものは、 例えば、 配列A[2]='30' 配列B[2]='000' 配列C[2]='1' 配列A[4]='30' 配列B[4]='000' 配列C[4]='1' は、1つの添え字にまとめたい。 その3つが一致したもの重複をまとめたいのと、 新しく出た3つの値は残したいのです。 つまり、以下のように抽出したいのです。 何か良い方法があれば教えて下さい。 perlで作成しています。 注)配列Cは空白もあります。 配列A( 10, 20, 30, 10, 30, 20) 配列B(000,010,000,010,000,000) 配列C( , 0, 1, 0, 1, 1) ↓ 配列D( 10, 20, 30, 10, 20) 配列E(000,010,000,010,000) 配列F( , 0, 1, 0, 1)
- ベストアンサー
- Perl
- 配列要素へのリファレンスと、要素の追加・削除について
ActivePerl v5.8.8 build 820 を使用しています。 配列要素へのリファレンスを取得し、その後要素の追加又は削除を行った場合 元の要素を参照し続けます。 (1) 要素の追加 @list = qw/a b c d/; $p = \$list[1]; print("$$p\n"); splice(@list, 1, 0, 'x'); print("$$p\n"); # 'b' が表示される # $list[2] を参照 ($list[1] ではない) (2) 要素の削除 @list = qw/a b c d/; $p = \$list[1]; print("$$p\n"); splice(@list, 1, 1); print("$$p\n"); # 'b' が表示される 質問1 これは perl の仕様としての動作でしょうか? それとも、実行系やバージョン などの環境に依存するものでしょうか? 質問2 要素の削除の場合、削除直後なのでたまたま元の値が表示されただけで、 削除した要素 'b' が格納されたメモリ空間はいつ上書きされるかわからない 状態なのでしょうか? それとも、上書きされることはないのでしょうか?
- ベストアンサー
- Perl
- 多次元配列の中で条件に合う要素の値を全て別の配列に入れるには
表題の処理を行うにはどうしたら良いでしょうか。 例: 要素名がxである値を別の配列にいれる input ( [a] => aaa [b] => Array ( [x] => 1 [y] => 2 ) [c] => Array ( [x] => 8 ) ) output ( [0] => 1 [1] => 8 )
- ベストアンサー
- PHP
- 2つの配列/キーが一致する際、要素数の出現回数を求
2つの配列があり、かつキーが一致する際、要素数の出現回数を求めたいのですが、 どうすれば良いでしょうか? 具体的には、下記「a、b」より「c、d」を導き出したいです ■元データ( a、b キーは対応) Array a ( [0] => 1 [1] => 2 [2] => 2 [3] => 1 [4] => 3 [5] => 1 [6] => 2 [7] => 2 [8] => 3 [9] => 1 ) Array b ( [0] => 0 [1] => 1 [2] => 0 [3] => 1 [4] => 1 [5] => 1 [6] => 1 [7] => 0 [8] => 2 [9] => 1 ) ■欲しい結果 Array c … 「Array b」が1の時の、「Array a」の値の出現回数(キーは「Array a」の値) ( [1] => 3 [2] => 2 [3] => 1 ) Array d … 「Array b」が1以外(0または2)の時の、「Array a」の値の出現回数(キーは「Array a」の値) ( [2] => 2 [1] => 1 [3] => 1 ) ■備考 「Array b」が1の時の「Array a」 [1] => 2 [3] => 1 [4] => 3 [5] => 1 [6] => 2 [9] => 1 ・1が3回 ・2が2回 ・3が1回 「Array b」が1以外の時の「Array a」 [0] => 1 [2] => 2 [7] => 2 [8] => 3 ・2が2回 ・1が1回 ・3が1回
- ベストアンサー
- PHP
お礼
参考のURLであっと言う間に解決いたしました。 ありがとうございました。