Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/100: Рейтинг темы: голосов - 100, средняя оценка - 4.94
3 / 3 / 0
Регистрация: 26.03.2011
Сообщений: 114

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

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

Студворк — интернет-сервис помощи студентам
Народ помогите! Проблема следующая. Я создал массив и заполнил его числами с помощью rand от -20 до 20. Как сделать так, чтобы при выводе чисел они не повторялись!
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.03.2011, 21:04
Ответы с готовыми решениями:

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

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

Матрица из случайных неповторяющихся чисел
Здравствуйте! В C++ я новичок (что по-моему и так понятно, иначе этого вопроса бы не было :D). Скажите, пожалуйста, как составить матрицу...

5
 Аватар для iama
1360 / 988 / 119
Регистрация: 30.07.2010
Сообщений: 5,297
30.03.2011, 21:09
Jaksn, рандомьте не сами элементы, а переставляйте элементы упорядоченой последовательности по рандому

Добавлено через 2 минуты
Поясню:
  1. Имеем упорядоченную последовательность an, an+1, ..., an+k
  2. В цикле от 0 до, скажем, k/2, генерируем число от 0 до k-1
  3. Меняем местами i-ый элемент с элементом под рандомным индексом
  4. PROFIT!
2
3 / 3 / 0
Регистрация: 26.03.2011
Сообщений: 114
30.03.2011, 21:58  [ТС]
Можешь написать как будет выглядеть фрагмент кода для моего случая, а то я что-то не очень понял, как нужно сделать?
0
 Аватар для iama
1360 / 988 / 119
Регистрация: 30.07.2010
Сообщений: 5,297
30.03.2011, 22:19
выкладывай свои наработки
0
32 / 32 / 7
Регистрация: 10.10.2010
Сообщений: 89
30.03.2011, 22:36
Может помочь рандомизирование с помощью системных часов.
Присоединяешь библиотеку
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
1183 / 468 / 87
Регистрация: 23.06.2009
Сообщений: 6,390
30.03.2011, 23:05
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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
30.03.2011, 23:05
Помогаю со студенческими работами здесь

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

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

генератор случайных чисел
как реализовать генератор случайных чисел? чтобы можно было вводить два числа(например 56 и 519), и случайное число генерировалось из...

Генератор случайных чисел
Пишу курсовую по криптографии, для генерации ключей, естественно, нужен генератор случайных чисел. Что вообще можно использовать в этом...

Генератор случайных чисел
Здорова господа! Нужно написать свой собственный генератор случайных чисел, такой же примерно как rand. От примерно написал кое...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru