Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
0 / 0 / 1
Регистрация: 12.04.2015
Сообщений: 21

Подсчет времени выполнения процедуры

28.02.2017, 09:25. Показов 1091. Ответов 2

Студворк — интернет-сервис помощи студентам
Такой вопрос- необходимо получить время выполнения процедуры сортировки массива.
Для этого я использовал следующее выражение
C++
1
2
3
4
5
6
7
8
9
10
void ExecuteSortingProccess()
    {
        tSort = clock();
        IterHoareSort(0, N - 1);
        tResTime = (double)(clock() - tSort) / CLOCKS_PER_SEC;
        }
void PrintStatistics() 
    {
        cout << "Время сортировки равно: " << tResTime << endl;
    }
Проблема в том, что для малых массивов (до 10000 эл.) при времени выполнения меньше, чем 0.001 оно выводит только 0 сек. Изменение формата вывода не помогает, он все равно выводит от 0.001000000, либо 0.0000000 если меньше 0.001
Как заставить его считать меньшие промежутки времени?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.02.2017, 09:25
Ответы с готовыми решениями:

Подсчет времени выполнения функции
Делаю 2 вида сортировки, не знаю как подсчитать их время. #include &lt;iostream&gt; #include &lt;time.h&gt; #include &lt;conio.h&gt; using...

Подсчет времени выполнения сортировки
Подскажите, пожалуйста, как написать в программе, чтобы подсчитывало время выполнения сортировки? Там как-то надо ввести &quot;clock...

Замер времени(тактов процессора) выполнения процедуры
Почему то замер дает отрицательный результат (при просмотре в режиме дебаг) и на выходе 0 в итоге. clock_t start, end; start =...

2
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
28.02.2017, 09:33
Цитата Сообщение от Jidkiy Arkadiy Посмотреть сообщение
Как заставить его считать меньшие промежутки времени?
Использовать не clock, а другой оператор. На форуме полно вопросов по этой теме.
0
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
28.02.2017, 10:08
http://rextester.com/FOJB98345
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
#include <chrono>
#include <utility>
 
namespace tools
{
    template<typename Duration, typename Func, typename... Args>
    typename Duration::rep timeForProcedure(Func func, Args&&... args)
    {
        auto start = std::chrono::system_clock::now();
        func(std::forward<Args>(args)...);
        auto end = std::chrono::system_clock::now();
        
        return std::chrono::duration_cast<Duration>(end - start).count();
    }
}
 
#include <iostream>
 
void foo()
{
    for (int i = 0; i < 100000; ++i)
        delete new int;
}
 
void bar(int n)
{
    for (int i = 0; i < n; ++i)
        delete new int;
}
 
int main()
{
    std::cout << "Hello, world!\n";
    
    std::cout << tools::timeForProcedure<std::chrono::milliseconds>(foo) << '\n';
    std::cout << tools::timeForProcedure<std::chrono::milliseconds>(bar, 10000000) << '\n';
}
Добавлено через 3 минуты
Возможные форматы:
http://en.cppreference.com/w/cpp/chrono/duration
Code
1
2
3
4
5
6
7
std::chrono::nanoseconds    duration</*signed integer type of at least 64 bits*/, std::nano>
std::chrono::microseconds   duration</*signed integer type of at least 55 bits*/, std::micro>
std::chrono::milliseconds   duration</*signed integer type of at least 45 bits*/, std::milli>
std::chrono::seconds    duration</*signed integer type of at least 35 bits*/>
std::chrono::minutes    duration</*signed integer type of at least 29 bits*/, std::ratio<60>>
std::chrono::hours  duration</*signed integer type of at least 23 bits*/, std::ratio<3600>>
Note: each of the predefined duration types covers a range of at least ±292 years.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.02.2017, 10:08
Помогаю со студенческими работами здесь

Полиморфизм времени выполнения/времени компиляции
Здравствуйте, подскажите, пожалуйста, литературу, где мне внятно можно узнать что такое полиморфизм ВРЕМЕНИ ВЫПОЛНЕНИЯ и ВРЕМЕНИ...

Время выполнения процедуры в С++ 3.1
Столкнулся с проблемой. Нужно подсчитать за сколько тактов процессора(времени) выполняется код процедуры. Стандартные функции С++ выдают...

Оптимизация времени выполнения
Доброго времени суток. Есть следующая задача. Задача олимпиадная, потому учитывается время выполнения, нужно вложится в 1секунду. Мой код...

Измерение времени выполнения
Подскажите пожалуйста как измерить время выполнения чего-то с наносекундной точностью. std::chrono::high_resolution_clock::time_point...

Ошибка времени выполнения
Я пишу проэкт в Visual Studia 2008 на C++. У меня есть несколько проблем. Во-первых, когда я собираю финальную версию (release) и...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru