Как мне поместить эти слова: @ {$ subset}, [@ext_subset], [$ last_item] в PHP? - PullRequest
1 голос
/ 12 марта 2010

У меня проблемы с переводом подпрограммы с Perl на PHP (я новичок в Perl). Вся подпрограмма выглядит следующим образом:

sub find_all_subsets {
  if (1 == scalar (@_)) {return [@_]}
  else {
    my @all_subsets = () ;
    my $last_item = pop (@_) ;
    my @first_subsets = find_all_subsets (@_) ;
    foreach my $subset (@first_subsets) {
      push (@all_subsets, $subset) ;
      my @ext_subset = @{$subset} ;
      push (@ext_subset, $last_item) ;
      push (@all_subsets, [@ext_subset]) ;
    }
    push (@all_subsets, [$last_item]) ;
    return (@all_subsets) ;
  }
}

Моя проблема в том, что я действительно не совсем понимаю синтаксис Perl, поэтому у меня возникают проблемы при написании этих @{$subset}, [@ext_subset] и [$last_item] на PHP.

Спасибо и извините, если вопрос глупый.

Ответы [ 5 ]

4 голосов
/ 12 марта 2010

[] - оператор ссылки на массив, для преобразования массива в ссылку на массив

@{} - оператор разыменования массива, превращающий ссылку на массив в массив

@a = (1,2,3);
$a = [ @a ];
@b = @{$a};       # now @b ==> (1,2,3)
2 голосов
/ 12 марта 2010

Когда я бегу

use Data::Dumper;
$Data::Dumper::Terse = 1;
$Data::Dumper::Indent = 0; 
my @x = (1,2,3,4);
my @y = find_all_subsets(@x);
foreach my $subset (@y) {
  print Dumper($subset), "\n";
}

(+ оригинальный скрипт) вывод

[1]
[1,4]
[1,3]
[1,3,4]
[1,2]
[1,2,4]
[1,2,3]
[1,2,3,4]
[2]
[2,4]
[2,3]
[2,3,4]
[3]
[3,4]
[4]

Обратите внимание на [] в выходных данных, мы вернемся к ним позже.

function find_all_subsets (array $x) {
  if ( 1>= count($x) ) { // the >= differs from the original script, use == or === if you want to keep it "more original"
    return array($x);
  } 
  else {
    $all_subsets = array();
    $last_item = array_pop($x);
    $first_subsets = find_all_subsets($x) ;
    foreach ($first_subsets as $subset) {
      array_push($all_subsets, $subset);
      array_push($subset, $last_item);
      array_push($all_subsets, $subset);
    }
    array_push ($all_subsets, array($last_item));
    return $all_subsets;
  }
}

$x = array(1,2,3,4);
$y = find_all_subsets($x);
foreach($y as $subset) {
  echo '(', join(',', $subset), ")\n";
}

1010 * производит *

(1)
(1,4)
(1,3)
(1,3,4)
(1,2)
(1,2,4)
(1,2,3)
(1,2,3,4)
(2)
(2,4)
(2,3)
(2,3,4)
(3)
(3,4)
(4)

пока все хорошо. Теперь вернемся к []. Data :: Dumper выбрал this [], а не (), потому что это не массив, а ссылка на массив (обнажите меня, если я не использую правильные термины; perl на самом деле не моя сильная сторона). Давайте изменим тестовый скрипт на perl и посмотрим на эффект, который имеют все эти эталонные вещи.

use Data::Dumper;
$Data::Dumper::Terse = 1;
$Data::Dumper::Indent = 0; 
$x2 = 2;
my @x = (1,\$x2,3,4);
my @y = find_all_subsets(@x);
$x2 = 99;
foreach my $subset (@y) {
  print Dumper($subset), "\n";
}

и вывод изменится на

[1]
[1,4]
[1,3]
[1,3,4]
[1,\99]
[1,\99,4]
[1,\99,3]
[1,\99,3,4]
[\99]
[\99,4]
[\99,3]
[\99,3,4]
[3]
[3,4]
[4]

Видите ли, я изменяю $ x2 после вызова функции find_all_subsets (), но все еще в результате используется новое значение, а Data :: Dumper помечает "значение" как ссылка (\ 99 вместо просто 99). Вам также нужна эта функция в вашем php-скрипте?

1 голос
/ 12 марта 2010

Примерно так:

@{$subset}    # Return array reference as an ordinary array, not applicable in PHP.
[@ext_subset] # Turn an array into an array reference, not applicable in PHP.
[$last_item]  # Create an array with $last_item as the only element, equal to array($last_item) in PHP.
0 голосов
/ 12 марта 2010

на случай, если вам нужно найти все подмножества, это выглядит так

function subsets($ary) {
    $out = array();
    $len = count($ary);
    for($i = 0; $i < (1 << $len); $i++) {
        for($p = array(), $j = 0; $j < $len; $j++)
            if($i & (1 << $j))
                $p[] = $ary[$j];
        $out[] = $p;
    }
    return $out;
}
0 голосов
/ 12 марта 2010

Так это правильно (в php)?

function find_all_subsets($array) {
    if (count($array) == 1) {
        return $array;
    }
    else {
        $all_subsets = array();
        $last_item = array_pop($array);
        $first_subsets = find_all_subsets($array);
        foreach ($first_subsets as $key => $val) {
            array_push($all_subsets, $val);
            $ext_subset[] = $val;
            array_push($ext_subset, $last_item);
            array_push($all_subsets, $ext_subset);
        }
        array_push($all_subsets, $last_item);
        return $all_subsets;
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...