С Новым годом! Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
259 / 205 / 60
Регистрация: 25.05.2022
Сообщений: 879
Excel

Выбрать случайно из списка без повторов

16.11.2022, 20:06. Показов 1078. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
На листе имеется именованный список длинной Х (1000+), требуется выбрать N случайных без повторов.

Вариант со случайной выборкой Х/N с последующим добавлением рандома от 1 до X/N не подходит 1) из-за возрастающей прогрессии и 2) скосе вероятности хвоста списка.

Как-то решается через формулы или VBA, чтобы совместимо с версией 2016?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.11.2022, 20:06
Ответы с готовыми решениями:

Из диапазона элементов случайно выводить элементы без повторов
Народ, как сделать такой скриптик: из диапазона элементов случайно выводить элементы по одному без повторов Думаю как-то через массивы....

Выбрать 5 из 20 без повторов
В конечном итоге нужно получить все возможные варианты 5 цифр из 20 Но, для упрощения я перевёл всё в (0..19) <?php ...

Выбрать случайное из 10 число, без повторов
Нужна функция, при вызове которой возвращала одно из 10 чисел, но каждый раз это число не должно повторятся!

3
932 / 365 / 43
Регистрация: 10.05.2021
Сообщений: 1,564
Записей в блоге: 10
16.11.2022, 20:14
Yuri V, для отбора уникальных нужен словарь или цикл по отсортированному (сами нагуглите) массиву
Удачи!
1
665 / 334 / 135
Регистрация: 16.07.2020
Сообщений: 953
16.11.2022, 22:14
Yuri V, Посмотрите такой набросок кода
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
Sub Unic_lst()
Dim Ar()
Dim N&, X&, i&, Nr&
Dim Dk As Object
Set Dk = CreateObject("Scripting.Dictionary") 'создаем словарь
Randomize
N = 10 'размер выборки
X = Range("Lst").Count 'количество элементов именованного списка
Ar = Range("Lst") 'именованный список в массив
i = 1 'вспомогательный счетчик для словаря
' заполняем словарь уникальными значениями из массива в случайном порядке
While Dk.Count < N
    Nr = WorksheetFunction.RandBetween(1, X) 'случайный номер элемента списка
    If Not Dk.Exists(Ar(Nr, 1)) Then
        Dk.Add Ar(Nr, 1), i
        i = i + 1
    End If
Wend
MsgBox ("Готово")
'выгружаем словарь куда требуется
End Sub
1
398 / 255 / 98
Регистрация: 04.11.2022
Сообщений: 378
16.11.2022, 23:53
Yuri V, список это столбец? Штатными средствами делается так: скопировать список на свободное место (новый лист), Данные - Удалить дубликаты. Заполнить соседний столбец формулой =СЛЧИС(), отсортировать полученную таблицу по столбцу со случайными, перенести N первых элементов списка куда нужно.
Реализация на VBA зависит от того, насколько часто меняется список или N. Можно оформить как пользовательскую функцию, как обработчик события изменения каких-то диапазонов, по кнопке и т.д.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.11.2022, 23:53
Помогаю со студенческими работами здесь

Выбрать первые несколько записей без повторов
Здравствуйте, У меня есть таблица из нескольких столбцов. Там два столбца (Дата, Путь сохранения). Мне нужно выбрать 3 пути по...

Максимальная сумма трех элементов списка без их повторов
# Задан список целых чисел. Написать функцию max_three_sum, # которая возвращает максимальную сумму трех элементов без их повторов # ...

Задан список слов. Необходимо выбрать из него случайное слово. Из выбранного случайного слова случайно выбрать букву и
Задан список слов. Необходимо выбрать из него случайное слово. Из выбранного случайного слова случайно выбрать букву и попросить...

Возврат списка, сформированный из исходного списка, но не содержащий повторов
Разработайте функции для выполнения следующих операций со списками: 7. Возврат списка, сформированный из исходного списка, но не...

Удаление из списка всех повторов
Возврат списка, который сформирован из первоначального списка, но не содержит повторов (остается только первый из одинаковых элементов).


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и источниками (напряжения, ЭДС и тока). Найти токи и напряжения во всех элементах. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru