Всем привет! У меня вопрос. Почему так сортируется правильно Код (PHP): $array[] = array('soc' => 3, 'code'=>1); $array[] = array('soc' => 2, 'code'=>1); $array[] = array('soc' => 1, 'code'=>1); $array[] = array('soc' => 1, 'code'=>1); $array[] = array('soc' => 2, 'code'=>5); $array[] = array('soc' => 1, 'code'=>2); $array[] = array('soc' => 3, 'code'=>2); //usage print_r("<pre>"); print_r(multiSort($array, 'soc', 'code')); print_r("</pre>"); function multiSort() { //get args of the function $args = func_get_args(); $c = count($args); if ($c < 2) { return false; } //get the array to sort $array = array_splice($args, 0, 1); $array = $array[0]; //sort with an anoymous function using args usort($array, function($a, $b) use($args) { $i = 0; $c = count($args); $cmp = 0; while($cmp == 0 && $i < $c) { $cmp = strcmp($a[ $args[ $i ] ], $b[ $args[ $i ] ]); $i++; } return $cmp; }); return $array; } а вот так Код (PHP): $array[] = array('soc' => 3, 'code'=>1); $array[] = array('soc' => 2, 'code'=>1); $array[] = array('soc' => 1, 'code'=>1); $array[] = array('soc' => 1, 'code'=>1); $array[] = array('soc' => 2, 'code'=>5); $array[] = array('soc' => 1, 'code'=>2); $array[] = array('soc' => 3, 'code'=>2); //usage print_r("<pre>"); print_r(multiSort($array, 'soc', 'code')); print_r("</pre>"); function multiSort() { //get args of the function $args = func_get_args(); $c = count($args); if ($c < 2) { return false; } //get the array to sort $array = array_splice($args, 0, 1); $array = $array[0]; //sort with an anoymous function using args usort($array, function($a, $b) use($args) { $i = 0; $c = count($args); $cmp = 0; while($cmp == 0 && $i < $c) { $cmp = ($a[ $args[ $i ] ] > $b[ $args[ $i ] ]) ? 1 : -1; $i++; } return $cmp; }); return $array; } неправильно. И вообще не очень понятно как именно эта сортировка работает. Сама процедура usort имеется ввиду. Она работает пузырьком? PHP, JavaScript, SQL и другой код пишите внутри тегов Код ( (Unknown Language)): [b]php][/b]Тут код[b][/[/b][b]code][/b][/color]