Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: [C++] Отсортировать массив случайным образом  (Прочитано 10697 раз)
0 Пользователей и 1 Гость смотрят эту тему.
The Nameless One
Помогающий

ru
Offline Offline
Пол: Мужской

« : 01-12-2010 17:57 » 

Есть обычный массив, элементы которого надо отсортировать в случайном порядке - "взбить" как молоко)
Где почитать, что делать?
Про STL ф-ию random_shaffle() слышал, но она только STL-же для контейнеров.
Есть ли смысл смотреть её исходники?
Подскажите, пожалуйста.
Записан
Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #1 : 01-12-2010 18:09 » 

если это шаблонная функция, то любой массив можно подсунуть, главное, чтоб для элемента был определён оператор присваивания
Записан

RXL
Технический
Администратор

ru
Offline Offline
Пол: Мужской

WWW
« Ответ #2 : 01-12-2010 18:11 » 

Википедия ссылается на Кнута "Искусство программирования, том 3. Сортировка и поиск". Если интересно, то стоит почитать.

Перемешать совсем не сложно: сделай два списка - список индексов элементов и пустой. В цикле вычисляй случайное значение от 0 до (размер_списка - 1) и перемещай данное значение из первого списка в конец второго. Когда первый список опустеет во втором будут значения индексов в случайном порядке - можно перемещать элементы из старого массива в новый согласно новому порядку. Можно не использовать индексы и перемещать сразу сами элементы, но зачастую работать с индексами дешевле в плане ресурсов.
Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
The Nameless One
Помогающий

ru
Offline Offline
Пол: Мужской

« Ответ #3 : 01-12-2010 18:17 » 

RXL, спасибо!

Добавлено через 1 минуту и 2 секунды:
Алексей1153++, да, можно и её:
int a[] = {1, 2, 3, 4, 5, 6, 7};
std::random_shuffle(a, a + sizeof(a) / sizeof(int));
« Последнее редактирование: 01-12-2010 18:18 от The Nameless One » Записан
Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #4 : 01-12-2010 18:20 » 

вот так лучше
std::random_shuffle(a, a + sizeof(a) / sizeof(*a) );
Записан

The Nameless One
Помогающий

ru
Offline Offline
Пол: Мужской

« Ответ #5 : 01-12-2010 18:27 » 

Алексей1153++, честно говоря, не очень понимаю, где разница? (*a) типа int же.
Записан
Алексей++
глобальный и пушистый
Глобальный модератор

ru
Offline Offline
Сообщений: 13


« Ответ #6 : 01-12-2010 18:34 » 

The Nameless One,

sizeof(a)  - размер статического массива в байтах
 sizeof(*a) - размер элемента массива в байтах
Улыбаюсь

Добавлено через 44 секунды:
разница в том, что не надо думать, какой там тип. Ведь он может и поменяться потом
« Последнее редактирование: 01-12-2010 18:35 от Алексей1153 » Записан

The Nameless One
Помогающий

ru
Offline Offline
Пол: Мужской

« Ответ #7 : 02-12-2010 07:16 » 

Да, спасибо)
Записан
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines