Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.66/29: Рейтинг темы: голосов - 29, средняя оценка - 4.66
6 / 8 / 8
Регистрация: 06.10.2017
Сообщений: 269
1

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

15.05.2018, 12:32. Показов 5255. Ответов 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
501 / 299 / 95
Регистрация: 06.03.2017
Сообщений: 1,163
15.05.2018, 12:33 2
unsigned long long - беззнаковый тип.
long long - если нужны целые числа со знаком.
double - для чисел с плавающей точкой ( не целые числа )
0
69 / 62 / 36
Регистрация: 26.07.2015
Сообщений: 126
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
Модератор
Эксперт С++
11066 / 9125 / 5483
Регистрация: 18.12.2011
Сообщений: 24,392
15.05.2018, 13:10 5
Лучший ответ Сообщение было отмечено Марина1211 как решение

Решение

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

Решение

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

Решение

Цитата Сообщение от Марина1211 Посмотреть сообщение
что будет если хранить в long double большое целое число?
Потеря точности. Целые числа и числа с плавающей точкой по разному представляются в памяти компьютера.
1
Evg
Эксперт CАвтор FAQ
21204 / 8220 / 633
Регистрация: 30.03.2009
Сообщений: 22,537
Записей в блоге: 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® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.