|
|
|
| Всем привет!
тут такая вещь, есть массив $_SESSION['quest'][$i] со значениями :21|22|25|26|27|28|29|30|31
потом я его перемешиваю shuffle($_SESSION['quest']); а потом опять вывожу, вот что получается: 31-27-26-28-30-29-29-25-26-22
1. Количество элементов на 1 больше
2. есть повторения
как избавиться от повторений??? | |
|
|
|
|
|
|
|
для: Spenser
(01.12.2007 в 19:00)
| | array_unique() | |
|
|
|
|
|
|
|
для: bronenos
(01.12.2007 в 19:19)
| | нет, надо перемешать массив но так чтобы не было одинаковых и количество элементов массива осталось прежним. | |
|
|
|
|
|
|
|
для: Spenser
(01.12.2007 в 19:36)
| | 1. Количество элементов на 1 больше
2. есть повторения
Мне само по себе это кажется странным. На мой взгляд, с этим надо разобраться, ибо такого быть не должно.
Я делаю вот так:
$m[0] = "Утро";
$m[1] = "День";
$m[2] = "Вечер";
$m[3] = "Вчера";
$m[4] = "Сегодня";
$m[5] = "Завтра";
echo "<br>", $m[0], $m[1], $m[2], $m[3], $m[4], $m[5];
shuffle($m);
echo "<br>", $m[0], $m[1], $m[2], $m[3], $m[4], $m[5];
|
И получаю:
УтроДеньВечерВчераСегодняЗавтра
ВчераЗавтраУтроДеньВечерСегодня | |
|
|
|
|
|
|
|
для: Владимир55
(01.12.2007 в 19:56)
| | а Вам что надо? все правильно 6 элементов. и в ответе 6, разном порядке... | |
|
|
|
|
|
|
|
для: ProtoTeeP
(01.12.2007 в 22:32)
| | У меня-то все в порядке, я и привел этот код для того, чтобы показать, как оно должно быть.
Но Вы почитайте, что пишет ТС. | |
|
|
|
|
|
|
|
для: Владимир55
(01.12.2007 в 23:21)
| | - | |
|
|
|
|
|
|
|
для: Spenser
(01.12.2007 в 19:00)
| | У меня такое впечатление, что shuffle в обязательном порядке использует нулевой элемент массива. А если этого элемента нет, то он его создает и сдвигает массив. И таким образом у ТС получается на один элемент больше, а дублем является тот, что попал в нулевой элемент, в паре с тем, что остался в массиве. | |
|
|
|
|
|
|
|
для: Владимир55
(02.12.2007 в 01:25)
| | вот привожу код как у меня:
$i = 0;
while ($quests = mysql_fetch_array($sql_quest))
{
$_SESSION['quest'][$i] = $quests['id_quest'];
echo $_SESSION['quest'][$i]."|";
$qaz2 = count($quests);
/* Перемешивание массива ответов */
$sql_ans = mysql_query("SELECT * FROM ".$prefix."_answers WHERE quest_ans='".$_SESSION['quest'][$i]."'");
$k = 0;
while ($ans = mysql_fetch_array($sql_ans))
{
$_SESSION['answer_'.$_SESSION['quest'][$i]][$k] = $ans['id_ans'];
$k++;
}
shuffle($_SESSION['answer_'.$_SESSION['quest'][$i]]);
$i++;
}
echo "<br>";
shuffle($_SESSION['quest']);
$qaz = count($_SESSION['quest']);
echo $qaz2."<br>";
echo $qaz."<br>";
$i = 0;
while ($i < $qaz)
{
echo $_SESSION['quest'][$i]."-";
$i++;
}
|
а вот результаты:
21|22|25|26|27|28|29|30|31|
10
9
22-31-26-30-29-28-25-27-21-
|
| |
|
|
|
|
|
|
|
для: Spenser
(02.12.2007 в 13:31)
| | разобрался вроде, ошибку так и не нашел,просто переделал и все заработало:))
спасибо всем за помощь! | |
|
|
|