Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.65/34: Рейтинг темы: голосов - 34, средняя оценка - 4.65
13 / 13 / 3
Регистрация: 24.04.2011
Сообщений: 122

Неповторяющийся random

09.03.2012, 14:11. Показов 6977. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день! Хочу сделать неповторяющийся рандум в конструкции switch(). Наподобие такого:

C++
1
2
3
4
5
6
7
8
int a=10;
randomize;
switch(random(a))
{
case 0: действие 1;
......
case 9: действие 10;
}
Т.е. мне надо, если сгенерируеться допустим число 5, то соответствующий кейз выполнится, а число 5 как бы исчезнет/удалится и не будет больше генерироваться рандумом. Надеюсь понятно объяснил. Такое вообще возможно сделать? Помогите пожалуйста
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.03.2012, 14:11
Ответы с готовыми решениями:

С++ random
Привет. Помогите пожалуйста сделать задание. Проблема в инициализации матрицы всем множеством трехзначных (только) вещественных чисел с...

C++ Random
Прошу помощи,что в этом коде не верно? Нужно чтобы v1-v7 после первого вывода больше не выводились. ...

random
Программа выдает случайно числа в диапазоне от 1 до 42 #include <math.hpp> int a = 1 ; int b = 43 ; int c ; c = RandomRange(a,b); ...

8
5 / 5 / 2
Регистрация: 12.02.2012
Сообщений: 44
09.03.2012, 14:40
нужно создать масив в которы будут записыватся числа которые уже были и проверять на совпадение при новом числе если такое число уже есть - рандом еще разок...
0
 Аватар для Sergey-K
238 / 229 / 58
Регистрация: 27.10.2011
Сообщений: 249
09.03.2012, 15:36
Например так:
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
43
44
45
//---------------------------------------------------------------------------
#include <vcl.h>
#pragma hdrstop
#include "Unit1.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
int n = 10;
int mas[10] = {0};
int mas_count = 0;
//---------------------------------------------------------------------------
void mas_clear()
{
  for(int i = 0; i < n; i++)
    mas[i] = 0;
  mas_count = 0;
}
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button1Click(TObject *Sender)
{
  int a;
  randomize();
  for(;;)
    {
      bool b = false;
      a = random(n);
      for(int i = 0; i < n; i++)
        if(a == mas[i])
          b = true;
      if(!b)
        break;
    }
  mas[mas_count] = a;
  mas_count++;
  if(mas_count > n - 2)
    mas_clear();
  ShowMessage(IntToStr(a));
}
//---------------------------------------------------------------------------
1
413 / 100 / 3
Регистрация: 07.09.2011
Сообщений: 532
Записей в блоге: 2
09.03.2012, 15:50
А использовать рекурсию и список для чисел - не варик? Задачка для школьника.
0
 Аватар для Sergey-K
238 / 229 / 58
Регистрация: 27.10.2011
Сообщений: 249
09.03.2012, 15:59
Будут не повторяющиеся числа от 1 до 9
Цитата Сообщение от Vega251 Посмотреть сообщение
Задачка для школьника
Примерчик не помешает
0
 Аватар для gumi250
435 / 402 / 57
Регистрация: 06.02.2012
Сообщений: 1,384
09.03.2012, 16:43
На сколько критична скорость и насколько критична рамдомность последних выпадающих цифр.
Пример Sergey-K плох по скорости. Когда останется мало цифр (последние две или одна), то цикл будет долго гоняться.

Добавлено через 24 минуты
Можно как то так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
const int N=10;
int m[N];
int Count=N;
for(int i=0; i<N; i++)
  m[i]=i;
 
int GetRandom()
{ int n=random(Count);
  int r=m[n];
  Count--;
  m[n]=m[Count];
  return r;
}
2
2022 / 1621 / 489
Регистрация: 31.05.2009
Сообщений: 3,005
09.03.2012, 16:48
Цитата Сообщение от Frizar Посмотреть сообщение
Т.е. мне надо, если сгенерируеться допустим число 5, то соответствующий кейз выполнится, а число 5 как бы исчезнет/удалится и не будет больше генерироваться рандумом. Надеюсь понятно объяснил. Такое вообще возможно сделать? Помогите пожалуйста
Хотелось бы более подробно услышать, в чём собственно состоит задача. В общем случае можно создать массив из необходимого набора чисел и перемешать
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <algorithm>
#include <cstddef>
#include <cstdlib>
#include <ctime>
 
...
 
const size_t n = 10;
int values[n] = {0,1,2,3,4,5,6,7,8,9};
   
std::srand(std::time(NULL));
std::random_shuffle(values, values + n);
   
for(size_t i = 0; i < n; ++i)  
{
   switch(values[i])
   {
      case 0: действие 1;
      ......
      case 9: действие 10;       
   }
}       
...
1
13 / 13 / 3
Регистрация: 24.04.2011
Сообщений: 122
09.03.2012, 20:28  [ТС]
Цитата Сообщение от rangerx Посмотреть сообщение
Хотелось бы более подробно услышать, в чем собственно состоит задача.
Ну в общем я небольшой тест написал и вопросы чередуются друг за другом, а я теперь хочу чтобы вопросы попадались на рандум.
0
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
09.03.2012, 20:29
Заполнить массив случайными неповторяющимися числами
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.03.2012, 20:29
Помогаю со студенческими работами здесь

random ()
Вопрос возник у меня,как мне сдлеать так,чтобы числа,допустим от 0 до 200 выбирались рандомно,но только парные?

Неповторяющийся рандом
Здравствуйте. Сделал неповторяющийся рандом, при запуске приложения зависает рабочая среда... Dim nm(31) As Integer Public Sub...

Создание теста, неповторяющийся список вопросов
Здравствуйте,не уверен была ли такая тема на форуме. Стоит задача сделать опрос с типами вопросов (1 из многих,несколько из многих,на...

Найти первый неповторяющийся элемент в массиве
Добрый день, подскажите пожалуйста, как найти в массиве 2 3 4 5 1 2 3 4 5 6 9 первый неповторяющийся элемент? т.е. в данном случае 1. ...

За единственный проход по массиву найти неповторяющийся элемент
здравствуйте, уважаемые программисты.) у меня такой вопросик: дан массив из нечетного кол-ва элементов, каждый из который встречается в...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru