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

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

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

Студворк — интернет-сервис помощи студентам
long long или long double
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
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 в степень p и возвращает ap. Помогите...

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

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

7
628 / 392 / 135
Регистрация: 06.03.2017
Сообщений: 1,469
15.05.2018, 12:33
unsigned long long - беззнаковый тип.
long long - если нужны целые числа со знаком.
double - для чисел с плавающей точкой ( не целые числа )
0
106 / 93 / 44
Регистрация: 26.07.2015
Сообщений: 197
15.05.2018, 12:39
Занимаемое место в памяти зависит от компилятора. Можешь проверить так
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  [ТС]
что будет если хранить в long double большое целое число?
0
Модератор
Эксперт С++
 Аватар для zss
13778 / 10971 / 6491
Регистрация: 18.12.2011
Сообщений: 29,258
15.05.2018, 13:10
Лучший ответ Сообщение было отмечено Марина1211 как решение

Решение

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

Решение

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

Решение

Цитата Сообщение от Марина1211 Посмотреть сообщение
что будет если хранить в long double большое целое число?
Потеря точности. Целые числа и числа с плавающей точкой по разному представляются в памяти компьютера.
1
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
15.05.2018, 23:22
Конкретно у 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);
}
Code
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);
}
Code
18446744073709551615
18446744073709551616.000000
18446744073709550591
18446744073709549568.000000
Для первого числа повезло и неточность оказалась всего 1, а для второго - не повезло, там потеряли 1023
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.05.2018, 23:22
Помогаю со студенческими работами здесь

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

Как 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 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1...

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

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


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru