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

Генератор случайных неповторяющихся чисел - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 36, средняя оценка - 4.97
Jaksn
3 / 3 / 0
Регистрация: 26.03.2011
Сообщений: 114
30.03.2011, 21:04     Генератор случайных неповторяющихся чисел #1
Народ помогите! Проблема следующая. Я создал массив и заполнил его числами с помощью rand от -20 до 20. Как сделать так, чтобы при выводе чисел они не повторялись!
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
iama
 Аватар для iama
1249 / 974 / 48
Регистрация: 30.07.2010
Сообщений: 5,297
30.03.2011, 21:09     Генератор случайных неповторяющихся чисел #2
Jaksn, рандомьте не сами элементы, а переставляйте элементы упорядоченой последовательности по рандому

Добавлено через 2 минуты
Поясню:
  1. Имеем упорядоченную последовательность an, an+1, ..., an+k
  2. В цикле от 0 до, скажем, k/2, генерируем число от 0 до k-1
  3. Меняем местами i-ый элемент с элементом под рандомным индексом
  4. PROFIT!
Jaksn
3 / 3 / 0
Регистрация: 26.03.2011
Сообщений: 114
30.03.2011, 21:58  [ТС]     Генератор случайных неповторяющихся чисел #3
Можешь написать как будет выглядеть фрагмент кода для моего случая, а то я что-то не очень понял, как нужно сделать?
iama
 Аватар для iama
1249 / 974 / 48
Регистрация: 30.07.2010
Сообщений: 5,297
30.03.2011, 22:19     Генератор случайных неповторяющихся чисел #4
выкладывай свои наработки
Tambel
32 / 32 / 2
Регистрация: 10.10.2010
Сообщений: 89
30.03.2011, 22:36     Генератор случайных неповторяющихся чисел #5
Может помочь рандомизирование с помощью системных часов.
Присоединяешь библиотеку
C++
1
#include <time.h>
а потом перед использованием генератора использовать функцию srand(time(0))

C++
1
2
3
4
5
6
int _tmain(int argc, _TCHAR* argv[])
{
    srand(time(0));
        // ваш код
    return 0;
}
^Tecktonik_KiLLeR
 Аватар для ^Tecktonik_KiLLeR
1144 / 426 / 19
Регистрация: 23.06.2009
Сообщений: 6,141
Завершенные тесты: 1
30.03.2011, 23:05     Генератор случайных неповторяющихся чисел #6
Tambel, не это имелось ввиду.

Jaksn, создайте функцию check типа bool, в функции, где заполняется массив,каждый раз вызывайте фунцкию check.
а в самой функции check должен работать такой алгоритм:
функция получает число К, если в массиве не было до К такого числа, которое равно самому К,то возвращать 1.
функция заполнения получает результат,если получил 1, то x[i]=rand()%41-20

Добавлено через 1 минуту
вот у меня пример не с массивом,а прямоугольной матрицей
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
void inp(int** x,int n,int m)
{
   int k;
   bool t;
   for(int i=0;i<n;i++)
   {
      for(int j=0;j<m;j++)
      {
         t=0;
         while(!t)
         {
            k=rand()%100+1;
            t=check(x,n,m,k);
         }
            *(*(x+i)+j)=k;
      }
 
   }
 
}
 
 
void out(int** x,int n,int m)
{
   for(int i=0;i<n;i++)
   {
      for(int j=0;j<m;j++)
         cout<<*(*(x+i)+j)<<" ";
      cout<<endl;
   }
}
 
 
bool check(int** x,int n,int m,int k)
{
   bool t=1;
   for(int i=0;i<n;i++)
      for(int j=0;j<m;j++)
         if(*(*(x+i)+j)==k)
            t=0;
         return t;
}
Yandex
Объявления
30.03.2011, 23:05     Генератор случайных неповторяющихся чисел
Ответ Создать тему
Опции темы

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