Самый быстрый шаффл строки

Revision ru1, by Gornak40, 2025-08-13 23:21:22

Представьте, что вам нужно перебрать много случайных перестановок строки и выполнить какую-то быструю проверку для каждой. Проверка настолько быстрая, что узким местом в вашем решении становится шаффл. Для простоты, в сниппете я ускорил проверку до no-op и добавил вывод финальной строки.

#include <bits/stdc++.h>
using namespace std;

#define ITER 10000

int main() {
    string s; cin >> s;
    for (int i = 0; i < ITER; ++i) {
        random_shuffle(s.begin(), s.end());
        // do_something(s);
    }
    cout << s << '\n';
}

Бенчмаркать будем на случайной строке длины $$$2 \cdot 10^5$$$. Кстати, на Unix системах получить такую строку очень просто.

tr -dc '[:alnum:]' < /dev/urandom | head -c 200000 > stroka.txt
Tags рандом, gnu, c++, язык с, бенчмарки

History

 
 
 
 
Revisions
 
 
  Rev. Lang. By When Δ Comment
ru9 Russian Gornak40 2025-08-14 01:03:52 0 (опубликовано)
en11 English Gornak40 2025-08-14 01:03:37 0 (published)
en10 English Gornak40 2025-08-14 01:01:19 79
en9 English Gornak40 2025-08-14 01:00:33 79 Tiny change: 'he winner!' -> 'he winner!\n\n![Chart](https://mirror.codeforces.com/aac5f4/chart.png)'
en8 English Gornak40 2025-08-14 00:54:39 1 Tiny change: 'Imagine yo' -> ' Imagine yo'
en7 English Gornak40 2025-08-14 00:52:52 3 Tiny change: ' user CPU runtime for t' -> ' user CPU time for t'
en6 English Gornak40 2025-08-14 00:51:52 15 Tiny change: ' seconds. Hooray, we've fo' -> ' seconds. Congratulations, we've fo'
en5 English Gornak40 2025-08-14 00:50:10 1 Tiny change: 'tware/libc enters th' -> 'tware/libc) enters th'
en4 English Gornak40 2025-08-14 00:49:41 15 Tiny change: 'd library sometimes contains useful fu' -> 'd library contains some useful fu'
en3 English Gornak40 2025-08-14 00:47:54 2 Tiny change: ' time was 26.78 seconds.\' -> ' time was $26.78$ seconds.\'
en2 English Gornak40 2025-08-14 00:47:03 1062
ru8 Russian Gornak40 2025-08-14 00:44:52 6
en1 English Gornak40 2025-08-14 00:43:42 3176 Initial revision for English translation (saved to drafts)
ru7 Russian Gornak40 2025-08-14 00:31:11 127
ru6 Russian Gornak40 2025-08-14 00:23:36 143
ru5 Russian Gornak40 2025-08-14 00:20:38 11 Мелкая правка: 'и добавил вывод финальной' -> 'и добавил печать финальной'
ru4 Russian Gornak40 2025-08-14 00:20:11 160
ru3 Russian Gornak40 2025-08-14 00:14:13 2065 Мелкая правка: 'ень просто: `tr -dc '[' -> 'ень просто.\n`tr -dc '['
ru2 Russian Gornak40 2025-08-13 23:22:31 26 Мелкая правка: 'troka.txt`\n' -> 'troka.txt`.\n'
ru1 Russian Gornak40 2025-08-13 23:21:22 794 Первая редакция (сохранено в черновиках)