Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/76: Рейтинг темы: голосов - 76, средняя оценка - 4.80
 Аватар для Dennis Ritchie
555 / 148 / 58
Регистрация: 27.07.2014
Сообщений: 2,446

Посчитать количество операций в коде и время выполнения

20.12.2014, 00:45. Показов 15980. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Я не понимаю условие данной задачи. Объясните, пожалуйста, как её делать.
Найти выражение вида c0 + c1N + c2N2 + c3N3, которое точно описывает время выполнения программы ниже. Сравнить время, задаваемое этим выражением, с реальным при N = 10, 100 и 1000.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include <ctime>
 
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "Russian");
    unsigned int start_time = clock();
    int i, j, k, count  = 0, n;
    cout << "n = ";
    cin >> n;
    for (i = 0; i < n; ++i)
        for (j = 0; j < n; ++j)
            for (k = 0; k < n; ++k)
                ++count;
    unsigned int end_time = clock();
    cout << count << endl;
    unsigned int search_time = end_time - start_time;
    cout << endl << "Время выполнения программы: " << search_time << " mc" << endl;
    system("pause");
    return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.12.2014, 00:45
Ответы с готовыми решениями:

Посчитать время выполнения программы
В среде visual studio 2012 можно? или в коде написать что нужно, подскажите

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

Оценить время выполнения и сложность простейших операций с разными типами данных
Меня интересует-вопрос: можно как-то оценить по-быстрому время, которое программа тратит на различные операции - сравнение, умножение,...

13
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
20.12.2014, 01:03
Dennis Ritchie, предлагается посчитать количество операций в коде, а затем загнать их в формулу.
1
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
20.12.2014, 01:05
Цитата Сообщение от Dennis Ritchie Посмотреть сообщение
Я не понимаю условие данной задачи. Объясните, пожалуйста, как её делать.
оценить время выполнения данного кода, в зависимости от n.
Цитата Сообщение от Dennis Ritchie Посмотреть сообщение
for (i = 0; i < n; ++i)
* * * * for (j = 0; j < n; ++j)
* * * * * * for (k = 0; k < n; ++k)
* * * * * * * * ++count;
Например, при n = 1 ++count выполнится 1 раз, при n = 2 - 8 раз, n = k - k^3 раз
Если время ++count - t, то при n = k, полное время составит t * k^3
1
 Аватар для mat_for_c
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
20.12.2014, 01:08
В данной программе ты вводишь N, и она делает свои операции за какое-то время. Чем больше N, тем больше время работы данной программы. Твоя задача найти коэффициенты многочлена - С0, C1, C2 и C3. Подставив в этот многочлен введенное N ты должен получить время работы.
+ тебя просят проверить на различных данных точное время и время, выдаваемое твоим многочленом...

Добавлено через 2 минуты
Цитата Сообщение от Jewbacabra Посмотреть сообщение
++count - t, то при n = k, полное время составит t * k^3
не забудьте ++i, ++j, ++k
1
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
20.12.2014, 01:13
Цитата Сообщение от mat_for_c Посмотреть сообщение
не забудьте ++i, ++j, ++k
В целом согласен, но еще хорошо бы посмотреть, что компилятор в итоге сделает с данным циклом
Цитата Сообщение от mat_for_c Посмотреть сообщение
а также cout,
не заметил что время начинает измеряться до cout
0
 Аватар для Dennis Ritchie
555 / 148 / 58
Регистрация: 27.07.2014
Сообщений: 2,446
20.12.2014, 01:16  [ТС]
Цитата Сообщение от mat_for_c Посмотреть сообщение
Твоя задача найти коэффициенты многочлена - С0, C1, C2 и C3.
А как найти эти коэффициенты с помощью программы?
0
 Аватар для mat_for_c
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
20.12.2014, 01:21
Цитата Сообщение от Jewbacabra Посмотреть сообщение
не заметил что время начинает измеряться до cout
кстати... а если число целый час не вводить тогда от N точно не зависит...

Добавлено через 1 минуту
либо start_time перед циклом стоять должен

Добавлено через 1 минуту
Цитата Сообщение от Dennis Ritchie Посмотреть сообщение
А как найти эти коэффициенты с помощью программы?
По хорошему нужно провести 4 теста, дабы решить 4 уравнения с 4 неизвестными...
0
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
20.12.2014, 01:23
Цитата Сообщение от mat_for_c Посмотреть сообщение
кстати... а если число целый час не вводить тогда от N точно не зависит...
не обязательно с клавиатуры вводить, можно входным потоком сделать, например, файл
0
 Аватар для mat_for_c
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
20.12.2014, 01:27
Цитата Сообщение от Jewbacabra Посмотреть сообщение
можно входным потоком сделать, например, файл
т.е. изменить чутка исходный код. тогда лучше, наверное, поставить перед циклом
C++
1
2
unsigned int start_time = clock();
for ...
0
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
20.12.2014, 01:32
Цитата Сообщение от mat_for_c Посмотреть сообщение
т.е. изменить чутка исходный код.
менять ничего не придется. Запускать примерно так:
Code
1
./prog_name < input.txt
1
 Аватар для Dennis Ritchie
555 / 148 / 58
Регистрация: 27.07.2014
Сообщений: 2,446
20.12.2014, 01:39  [ТС]
А можете, пожалуйста, написать программу. Я смысл понял, но сам не напишу решение системы из четырёх уравнений.

Добавлено через 3 минуты
Цитата Сообщение от Jewbacabra Посмотреть сообщение
Code
1
./prog_name < input.txt
Это вы про запуск на Linux'e?
0
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
20.12.2014, 01:46
Цитата Сообщение от Dennis Ritchie Посмотреть сообщение
А как найти эти коэффициенты с помощью программы?
Можно разделить операции на:
1) не зависящие от N
2) зависящие от N
3) зависящие от N * N
4) зависящие от N * N * N

Честно говоря, не вижу смысла тут решать какие-то системы уравнений. Задача же не предполагает этого, там нужно просто определить сколько операций относится к п.1, сколько к п.2, и т.д. Это и будут наши коэффициенты С1, С2 и т.д.

Добавлено через 6 минут
mat_for_c, вот я сейчас открыл Седжвика, нашел это задание. Никаких cout там нет. Там есть только вот этот отрывок и все.
C++
1
2
3
4
5
    int i, j, k, count  = 0;
    for (i = 0; i < n; ++i)
        for (j = 0; j < n; ++j)
            for (k = 0; k < n; ++k)
                ++count;
Так что усложнять себе задачу размышлениями о том, что пользователь не будет вводить числа целый час не стоит. Седжвик просит оценить только приведенный код, не более.
1
 Аватар для Dennis Ritchie
555 / 148 / 58
Регистрация: 27.07.2014
Сообщений: 2,446
20.12.2014, 01:53  [ТС]
Цитата Сообщение от DrOffset Посмотреть сообщение
Так что усложнять себе задачу размышлениями о том, что пользователь не будет вводить числа целый час не стоит. Седжвик просит оценить только приведенный код, не более.
Да, нужно просто решить задачу 2.3, использую для этого данные из задачи 2.2. Просто сначала я неправильно понял условие.
0
 Аватар для mat_for_c
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
20.12.2014, 11:32
Цитата Сообщение от DrOffset Посмотреть сообщение
открыл Седжвика, нашел это задание

Не по теме:

а есть вообще 3-й том (части 6-8) книги???

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.12.2014, 11:32
Помогаю со студенческими работами здесь

Время выполнения операций
Как узнать какое время у процессора займет выполнение какого либо действия. К примеру я на форме прорисовывал многоугольник с помощью 4-х...

Замерить время выполнения базовых операций
собственно, нужно замерить время выполнени +-*/ для всех типов. делал следующим образом double empty = 0; Stopwatch...

Найдите ошибку в коде выполнения арифметических операций по выбору
Помогите найти ошибку. VAR a,b:integer; znak:char; BEGIN ReadLn(a); ReadLn(znak); ReadLn(b); case znak of '+'...

Ноутбук сильно тормозит во время выполнения файловых операций
Когда на ноутбуке выполняется длительная файловая операция, например, копирование большого количества файлов с внешнего ЖД, по локальной...

Зависание приложение во время выполнения каких-либо операций
Здрати.. У меня приложение на время выполнения цикла или вовремя запроса до URL зависает полностью... На 100-200мс Как сделатьт что бы...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru