Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- //Урок 3: Измеряем время
- #include <cstdlib>
- #include <iostream>
- #include <vector>
- #include <chrono>
- using namespace std;
- using namespace chrono;
- vector<int> ReverseVector(const vector<int>& source_vector) {
- vector<int> res;
- for (int i : source_vector) {
- res.insert(res.begin(), i);
- }
- return res;
- }
- int CountPops(const vector<int>& source_vector, int begin, int end) {
- int res = 0;
- for (int i = begin; i < end; ++i) {
- if (source_vector[i]) {
- ++res;
- }
- }
- return res;
- }
- void AppendRandom(vector<int>& v, int n) {
- for (int i = 0; i < n; ++i) {
- // получаем случайное число с помощью функции rand.
- // с помощью (rand() % 2) получим целое число в диапазоне 0..1.
- // в C++ имеются более современные генераторы случайных чисел,
- // но в данном уроке не будем их касаться
- v.push_back(rand() % 2);
- }
- }
- void Operate() {
- vector<int> random_bits;
- // операция << для целых чисел это сдвиг всех бит в двоичной
- // записи числа. Запишем с её помощью число 2 в степени 17 (131072)
- static const int N = 1 << 17;
- // заполним вектор случайными числами 0 и 1
- auto start_time = steady_clock::now();
- AppendRandom(random_bits, N);
- auto end_time = steady_clock::now();
- auto dur = end_time - start_time;
- // перевернём вектор задом наперёд
- auto start_time1 = steady_clock::now();
- vector<int> reversed_bits = ReverseVector(random_bits);
- auto end_time1 = steady_clock::now();
- auto dur1 = end_time1 - start_time1;
- // посчитаем процент единиц на начальных отрезках вектора
- auto start_time2 = steady_clock::now();
- for (int i = 1, step = 1; i <= N; i += step, step *= 2) {
- // чтобы вычислить проценты, мы умножаем на литерал 100. типа double;
- // целочисленное значение функции CountPops при этом автоматически
- // преобразуется к double, как и i
- double rate = CountPops(reversed_bits, 0, i) * 100. / i;
- cout << "After "s << i << " bits we found "s << rate << "% pops"s
- << endl;
- }
- auto end_time2 = steady_clock::now();
- auto dur2 = end_time2 - start_time2;
- cerr << "Append random: "s << duration_cast<milliseconds>(dur).count() << " ms"s << endl
- << "Reverse: "s << duration_cast<milliseconds>(dur1).count() << " ms"s << endl
- << "Counting: "s << duration_cast<milliseconds>(dur2).count() << " ms"s << endl;
- }
- int main() {
- Operate();
- return 0;
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement