С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 36, средняя оценка - 4.97
Jaksn
3 / 3 / 0
Регистрация: 26.03.2011
Сообщений: 114
#1

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

30.03.2011, 21:04. Просмотров 5508. Ответов 5
Метки нет (Все метки)

Народ помогите! Проблема следующая. Я создал массив и заполнил его числами с помощью rand от -20 до 20. Как сделать так, чтобы при выводе чисел они не повторялись!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
30.03.2011, 21:04
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Генератор случайных неповторяющихся чисел (C++):

Генератор неповторяющихся семизначных чисел - C++
Всем здравствуйте! Очень нужна Ваша помощь. При написании программы столкнулась с проблемой в рандоме. Нужно, чтобы на экран выводились...

Массив случайных неповторяющихся чисел - C++
Ребят работал всю ночь и сейчас голова не пашет! объясните в чем проблема private: System::Void button2_Click(System::Object^ sender,...

Составить функцию, которая возвращает N случайных неповторяющихся целых чисел из диапазона - C++
Помогите плизз Составить функцию, которая возвращает N случайных неповторяющихся целых чисел из диапазона . Главная...

Генератор случайных чисел - C++
Добрый день!У меня есть код #include <iostream> #include <cstdlib> #include <cstring> #include <ctime> char randSym() { ...

Генератор случайных чисел - C++
Здраствуййте :( int a=rand()%10000; std::cout << a; getchar(); return 0; int a=rand()%1000; std::cout << a; getchar();...

Генератор случайных чисел - C++
Еще одна тема о генераторе. Только вопрос, на который я пока не нашел ответа в других темах. Как сгенерировать случайное число в двух или...

5
iama
1251 / 976 / 49
Регистрация: 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!
1
Jaksn
3 / 3 / 0
Регистрация: 26.03.2011
Сообщений: 114
30.03.2011, 21:58  [ТС] #3
Можешь написать как будет выглядеть фрагмент кода для моего случая, а то я что-то не очень понял, как нужно сделать?
0
iama
1251 / 976 / 49
Регистрация: 30.07.2010
Сообщений: 5,297
30.03.2011, 22:19 #4
выкладывай свои наработки
0
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;
}
1
AnonymC
1173 / 455 / 28
Регистрация: 23.06.2009
Сообщений: 6,342
Завершенные тесты: 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;
}
1
30.03.2011, 23:05
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
30.03.2011, 23:05
Привет! Вот еще темы с ответами:

Генератор случайных чисел - C++
В общем, нужно составить программу, которая реализует алгоритм генерации случайных чисел. Естественно не используя random. Перерыла массу...

Генератор случайных чисел - C++
Есть функция, генерирующая случайные целые числа с помощью линейного конгруэнтного метода. Нужно сделать частотный побитовый тест для...

Генератор случайных чисел - C++
Здравствуйте! Кто-нибудь объясните пожалуйста. Вот есть функция rand(). Она возвращает псевдослучайные числа от нуля до RAND_MAX. А можно...

Генератор случайных чисел - C++
Помогите написать программу, которая генерировала бы случайные числа мультипликативным конгруэнтным методом. Нужно использовать такое...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.