6 / 8 / 8
Регистрация: 06.10.2017
Сообщений: 269
1

Чем различаются long long и long double?

15.05.2018, 12:32. Показов 7772. Ответов 7
Метки нет (Все метки)

long long или long double
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
15.05.2018, 12:32
Ответы с готовыми решениями:

Требуется написать функцию long long pow(long long a, unsigned int p), которая возводит число a в степень p
Требуется написать функцию long long pow(long long a, unsigned int p), которая возводит число a в...

Не понятный undefined reference to `unsigned long long f<unsigned long long, void>
test.cpp: #include &lt;iostream&gt; template &lt;typename FormalType, typename FactType = typename...

Возведение в степень по модулю для чисел близких к max long long
Даны числа A,B,C&lt;=2^63-1 Надо посчитать A^B mod С. прошу не выкладывать стандартный алгоритм для...

Нюансы синтаксиса: что означает запись typedef long long i64 ?
Что означает эта строчка? typedef long long i64; Как я понял, функция typedef позволяет...

7
610 / 375 / 134
Регистрация: 06.03.2017
Сообщений: 1,377
15.05.2018, 12:33 2
unsigned long long - беззнаковый тип.
long long - если нужны целые числа со знаком.
double - для чисел с плавающей точкой ( не целые числа )
0
91 / 80 / 40
Регистрация: 26.07.2015
Сообщений: 177
15.05.2018, 12:39 3
Занимаемое место в памяти зависит от компилятора. Можешь проверить так
C++
1
sizeof(long long)
А максимальное значение узнать так
C++
1
std::numeric_limits<long double>::max()
Вот только long double это число с плавающей точкой, так что хранить в нём целые числа плохая идея.
0
6 / 8 / 8
Регистрация: 06.10.2017
Сообщений: 269
15.05.2018, 12:59  [ТС] 4
что будет если хранить в long double большое целое число?
0
Модератор
Эксперт С++
12636 / 10131 / 6101
Регистрация: 18.12.2011
Сообщений: 27,165
15.05.2018, 13:10 5
Лучший ответ Сообщение было отмечено Марина1211 как решение

Решение

Числа с плавающей точкой преобразуются в десятичные (и наоборот) лишь с некоторой точностью.
Поэтому не удивляйтесь если выполняя
C++
1
2
long double a=123;
cout<<a;
получите такой вывод
122.999999
1
91 / 80 / 40
Регистрация: 26.07.2015
Сообщений: 177
15.05.2018, 13:49 6
Лучший ответ Сообщение было отмечено Марина1211 как решение

Решение

И чем больше числа будут использоваться, тем больше будет погрешность. Вот пример для float32.
Если попробовать сохранить число
C++
1
123456789012345678901234567890123456789
То сохраниться оно в формате
C++
1
1.4512275457382202 * 2^126
что равняется
C++
1
123456786051166514360985072406712287232
Т.е. ошиблась на 10 в 30 степени.
1
Форумчанин
Эксперт CЭксперт С++
8193 / 5043 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
15.05.2018, 13:50 7
Лучший ответ Сообщение было отмечено Марина1211 как решение

Решение

Цитата Сообщение от Марина1211 Посмотреть сообщение
что будет если хранить в long double большое целое число?
Потеря точности. Целые числа и числа с плавающей точкой по разному представляются в памяти компьютера.
1
Evg
Эксперт CАвтор FAQ
21264 / 8280 / 637
Регистрация: 30.03.2009
Сообщений: 22,635
Записей в блоге: 30
15.05.2018, 23:22 8
Конкретно у long double мантисса 64-битная. Т.е. 64-битный unsigned long long влезет в long double без потери точности

C
#include <stdio.h>
 
long double ld;
unsigned long long ull = 0xFFFFFFFFFFFFFFFFull;
 
int main (void)
{
  printf ("%llu\n", ull);
 
  ld = ull;
  printf ("%Lf\n", ld);
}
Код
18446744073709551615
18446744073709551615.000000
Можно поиграться с другими значениями, везде будет совпадать

Но на древних системах long double может быть эквивалентным double'у, у которого мантисса 53-битная, а потому у 64-битного целого могут быть потери до 11 бит (т.е. для больших чисел потеря точности будет до +-1024)

C
#include <stdio.h>
 
double d;
unsigned long long ull1 = 0xFFFFFFFFFFFFFFFFull;
unsigned long long ull2 = 0xFFFFFFFFFFFFFFFFull - 1024;
 
int main (void)
{
  printf ("%llu\n", ull1);
  d = ull1;
  printf ("%f\n", d);
 
  printf ("%llu\n", ull2);
  d = ull2;
  printf ("%f\n", d);
}
Код
18446744073709551615
18446744073709551616.000000
18446744073709550591
18446744073709549568.000000
Для первого числа повезло и неточность оказалась всего 1, а для второго - не повезло, там потеряли 1023
2
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
15.05.2018, 23:22
Помогаю со студенческими работами здесь

Как char[] перевести в битовую маску long long(64 бита) и наоборот?
Как char перевести в битовую маску long long(64 бита) и наоборот?

Меняется ответ при приведении функции pow к unsigned long long
Тест: 50 50 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1...

Тип long long и его ввод\вывод с использованием scanf\printf
Добрый день! Мне в программе надо вывести и ввести, соответственно, некоторые данные с помощью...

Вызвано исключение при инициализации массива long long int
long long int c = {}; Если убрать один long, программа запускается и работает нормально. Почему?


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru