Форум программистов, компьютерный форум CyberForum.ru

Неправильный рандом - C++

Восстановить пароль Регистрация
 
MMXII
0 / 0 / 0
Регистрация: 05.04.2013
Сообщений: 10
10.06.2013, 20:15     Неправильный рандом #1
Здравствуйте. Программа должна заполнять массив случайными, не повторяющимися элементами. Однако не смотря на то что максимальное значение случайных элементов было задано 50, массив заполняется любыми числами, в том числе и очень большими. Как это исправить?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
 int a[20],i,j,b;
                 bool flag;
                 for(i=0;i<20;i++)
                 {
                     flag=false;
                     b=rand()%50;
                     for (j=0;j<=i;j++)
                     {
                    if(a[j]==b) flag=true;
                     }
                     if(!flag) a[i]=b;
                 }
                  for(i=0;i<20;i++)
                  {
                   textBox1->Text+=a[i].ToString()+"\r\n";
                  }
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.06.2013, 20:15     Неправильный рандом
Посмотрите здесь:

Рандом C++
рандом C++
Рандом C++
Рандом C++
Рандом C++
рандом C++
Рандом C++
C++ Рандом

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Гром
 Аватар для Гром
199 / 118 / 10
Регистрация: 20.03.2009
Сообщений: 1,075
Записей в блоге: 15
10.06.2013, 20:26     Неправильный рандом #2
Рандом ни при чем. Просто у вас проверяется, нет ли совпадения с одним из предыдущих элементов, если нет - записывается сгенерированное значение, а если есть - повторной генерации не происходит, вы переходите к следующему элементу. То есть в этом случае вы просто не присвоили элементу массива никакого значения, и там оказался мусор.
Оберните код проверки и генерации в цикл while:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
for (int i = 0; i < 20; ++i)
 {
 bool Ok = false;
 while (! flag)
  {
  Ok = true;
  b = rand() % 50;
  for (j = 0; j < i; ++j)
   if (a[j] == b)
    Ok = false;
  }
 a[i] = b;
 }
Yandex
Объявления
10.06.2013, 20:26     Неправильный рандом
Ответ Создать тему
Опции темы

Текущее время: 08:48. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru