Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
KeyGen
384 / 291 / 6
Регистрация: 07.08.2011
Сообщений: 790
Записей в блоге: 1
#1

double быстрее всех? - C++

19.09.2012, 20:42. Просмотров 654. Ответов 1
Метки нет (Все метки)

В книге Прата написано что int быстрей... я не поверил на слово и решил проверить.
Написал простую программу:

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
#include <iostream>
#include <time.h>
 
template<class T> void frequency_of_primes (int n, T number) {
    
    T Ttemp;
    for(int i = 0; i<n; i++)
    {
        Ttemp = number * number;
        Ttemp = number / number;
        Ttemp = number + number;
        Ttemp = number - number;
    }
}
 
int main ()
{
  std::cout << "Calculating...\n";
  
  //char temp = 2;      // char = 5.8
  //short temp = 2;     // short = 5.77
  //int temp = 2;       // int = 5.5
  //long temp = 2;      // long = 5.5
  //long long temp = 2; // long long = 18.53
  
  double temp = 2.0; // double = 4.82
  //float temp = 2.0; // float = 5.59
  
  frequency_of_primes (999999999, temp);
  
  std::cout << "Мне потребовалось: " << ((float)clock())/CLOCKS_PER_SEC << " секунд.\n";
  std::cin.get();
  return 0;
}
Вот что получилось:

char = 5.8 (сек.)
short = 5.77 (сек.)
int = 5.5 (сек.)
long = 5.5 (сек.)
long long = 18.53 (сек.)

double = 4.82 (сек.) !!!
float = 5.59 (сек.)

_________________________________
Проц: 2x2.3
Компилятор: gcc 4.7
Cистема: Linux 32(86)

Не верю глазам. Может что не так в программе?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.09.2012, 20:42
Здравствуйте! Я подобрал для вас темы с ответами на вопрос double быстрее всех? (C++):

Ошибки error C2296: -: недопустимо, левый операнд имеет тип "double (__cdecl *)(double,double,double - C++
Думаю из-за polp #include&lt;iostream&gt; #include&lt;cmath&gt; #include&lt;cstdlib&gt; using namespace std; double polp(double af,double...

Ошибка: error LNK2001: unresolved external symbol "double __cdecl Akk(double,double,double)" - C++
#include &lt;iostream&gt; #include &lt;cmath&gt; using namespace std; double Akk(double x, double y, double z); int main() { int a, b, c; ...

Почему мы пишем double x (double y)? а не через запятую double x,y - C++
почему мы пишем double x (double y)? а не через запятую double x,y

Исправить ошибки "cannot convert 'double (*)(double)' to 'double'" и "too many arguments to function" - C++
пожалуйста проверьте и помогите исправить ошибки: #include&lt;iostream&gt; #include&lt;stdio.h&gt; #include&lt;math.h&gt; #include&lt;stdlib.h&gt; ...

Преобразовать 2 числа int в 1 число float(double) | double int1.int2 - C++
Всем привет. Изучая азы C++, столкнулся с такой проблемой. Есть два значения типа int, их необходимо преобразовать в одно значение типа...

Почему перестает работать программа при замене double на long double? - C++
Здравствуйте! Прошу помощи чтобы разобраться в следующем вопросе: Нашел программу в интернете, запустил - все работает, но когда решил...

1
OhMyGodSoLong
~ Эврика! ~
1244 / 993 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
19.09.2012, 20:49 #2
Всё нормально. long long не влазит в один регистр, только в два, поэтому есть тормоза. double множится-делится сопроцессором, он специализированный, у него получается это делать быстрее (для чисел с плавающей запятой). double лучше подходит под размер его регистров, поэтому работает чуть быстрее float.
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
19.09.2012, 20:49
Привет! Вот еще темы с ответами:

Какая-нибудь реализация функции void Fun (double in, double *out) - C++
Подскажите, пожалуйста, какую-нибудь любую реализацию прототипа функции: void Fun (double in, double *out)

long double и double в MSVC 12 одно и тоже, нужна информация,желательно быстрей - C++
Здравствуйте все знают что в VC long double и double одно и тоже, да и при простой проверке это легко выясняется, но нужна информация от...

Error: invalid types 'double [10][10][double]' for array subscript - C++
В 20 21 и 23 строках выдает ошибку error: invalid types 'double ' for array subscript #include &lt;iostream&gt; #include &lt;conio.h&gt; #include...

invalid operands of types ‘double*’ and ‘double’ to binary ‘operator*’ - C++
#include &quot;mpi.h&quot; #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; #include &lt;math.h&gt; #define count 120 int main(int argc,char *argv) { ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru