Последние записи
- TChromium (CEF3), сохранение изображений
- Как в Delphi XE обнулить таймер?
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
4th
Сен
Перемешивание очень длинной последовательности. Тасование Фишера-Йетса
Posted by obzor under c/c++
Стоит задача случайно перемешать последовательность символов длинной около 70 млн символов. Подскажите как это проще всего реализовать?
я же правильно понимаю, у Вас есть последовательность символов, нужно эти символы переставить в последовательности случайным образом, так?
где символы хранятся? если в массиве, то перемешать можно легко за один проход по массиву (ну, разумеется, будет ~70*2 миллионов перестановок.
перемешать можно по алгоритму отсюда
Набросал пример на Си, реализующий алгоритм тасование Фишера-Йетса:
#include <stdlib.h>
#include <stdio.h>
#include <conio.h>
#include <time.h>
int main(){
const int n=100;
int mas[n];
srand(time(NULL));
for(int i=0; i<n; i++)
mas = i;
for(int i=n-1; i>0; i--){
int k=rand()%(i+1);
int tmp=mas;
mas=mas[k];
mas[k]=tmp;
}
for(int i=0; i<n; i++)
printf("%d ", mas);
getch();
return 0;
}
Но стоит отметить, что в чистом Си rand() дает случайное число 0..32767, то есть для 70 млн неприменим.
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)