Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/64: Рейтинг темы: голосов - 64, средняя оценка - 4.94
0 / 0 / 0
Регистрация: 13.01.2019
Сообщений: 15

Вывод большого числа знаков после запятой в текстовый файл

10.04.2019, 13:36. Показов 12717. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет! Нужно что бы в текстовый файл записывалось 48 знаков после запятой, а записывает только 4.
Что можно сделать? Использую std::ofstream.

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 "pch.h"
#include <iostream>
#include <math.h>
#include <vector>
#include <fstream>
 
 
 
int main()
 
{
    double a = -2.08, n = 5, h = 0.04;
 
    std::cout << "X" << "\t" << "Y" << std::endl;
    std::vector <double> x = {};
    std::vector <double> y = {};
 
    std::ofstream fout("E://cppstudio.txt");
 
    for (int i = 0; i <= n; i++)
    {
        x.push_back(a + h * i);
        y.push_back(8 * sqrt(pow(x[i] + 2, 2) + 3));
 
        std::cout.precision(2);
        std::cout << std::fixed << x[i] << " | ";
        std::cout.precision(48);
        std::cout << y[i] << std::endl;
        fout << y[i];
        fout << "\n";
    }
 
    fout.close();
}
В текстовый файл записывается
13.8712
13.8601
13.8564
13.8601
13.8712
13.8896
Миниатюры
Вывод большого числа знаков после запятой в текстовый файл  
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
10.04.2019, 13:36
Ответы с готовыми решениями:

Ограничить у числа вывод знаков после запятой
Подскажите пожалуйста, как сделать, чтобы ограничить у числа вывод знаков после запятой, когда мы его выводим в Label1?

Вывод числа с ограниченным количеством знаков после запятой
float m; m = (6.0221412927*pow(10,23.0))/23; cout &lt;&lt;&quot;Количество атомов в 1 мг Натрия = &quot;&lt;&lt;m&lt;&lt;endl&lt;&lt;endl; Как...

Вывод числа с нужным мне количеством знаков после запятой
Подскажите пожалуйста, мне надо, чтобы выводилось два знака после запятой: using System; namespace ConsoleApplication1 { ...

8
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
10.04.2019, 13:41
Leddau, и как ты себе это представляешь, 48 знаков уместить в восьми байтах?
Если бы порядок числа был крайне мал, ещё можно было бы наппечатать незначащих нулей перед числом,
но вот так вот, дабл хранит лишь 8 байт из них на мантиссу и того меньше
1
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
10.04.2019, 13:41
Лучший ответ Сообщение было отмечено Leddau как решение

Решение

Leddau,
C++
1
2
3
4
//...
fout.precision(48);
fout << y[i];
//...
1
0 / 0 / 0
Регистрация: 13.01.2019
Сообщений: 15
10.04.2019, 13:51  [ТС]
zayats80888, сработало! От души!

13.8711787530836758719487988855689764022 827148438
13.8601010097329364612050994765013456344 604492188
13.8564064605510175454128329874947667121 887207031
13.8601010097329364612050994765013456344 604492188
13.8711787530836758719487988855689764022 827148438
13.8896220250948516650169040076434612274 169921875
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
10.04.2019, 14:56
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
int main() {
    double x;
    unsigned char* p = (unsigned char*)&x;
    x= 13;// тринадцать побайтово выглядит так
    //p[7] = 0x40;
    //p[6] = 0x2A;
    //p[5] = 0x00;
    //p[4] = 0x00;
    //p[3] = 0x00;
    //p[2] = 0x00;
    //p[1] = 0x00;
    //самое минимальное увеличение числа
    p[0] = 0x01;//увеличиваем самый младший бит числа на 1 (у ровно 13 этот бит 0)
    std::cout.precision(48);//хотим увидеть 13, порядка 48 нулей и 1
    std::cout << x << std::endl;//но видим, как ни странно,
// единицу в пятнадцатом знаке после запятой
    //то есть точность твоя не 48, а полное фуфло
    return 0;
}
1
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
10.04.2019, 15:07
по сути это доказывает, что в типе дабл
13.00000000000000 есть такое число
13.0000000000000012345678901234567890 нет такого числа
13.00000000000001 есть такое число
0
0 / 0 / 0
Регистрация: 13.01.2019
Сообщений: 15
10.04.2019, 16:56  [ТС]

Не по теме:

Kuzia domovenok, а вы не из робкого десятка! Я далек от понимания настолько глубокого машинного процесса с байтами. Циферки в простом варианте меня полностью устроили, и я выбрал его. Более того, я еще не изучал что такое unsigned char*, а про то что в коде можно разбирать числа побайтово узнал в первый раз :)

Я понимаю, нужно учитывать что в машинном понимании, условное число 3 превратится в 2.(9). Это все усложняет, и я бы никогда не захотел возвращаться к этой теме. И все же, если приспичит, как мне записать числа из моей формулы (8 * sqrt(pow(x[i] + 2, 2) + 3)) с максимальной точностью? Какую литературу почитать по этому вопросу?




upd:
Я изменил precision на 50 вместо 48, получилось точь-в-точь как в консоли. Только нули не отображаются. Разве это фуфло???

13.8711787530836758719487988855689764022 8271484375
13.8601010097329364612050994765013456344 6044921875
13.8564064605510175454128329874947667121 88720703125
13.8601010097329364612050994765013456344 6044921875
13.8711787530836758719487988855689764022 8271484375
13.8896220250948516650169040076434612274 169921875
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
10.04.2019, 17:00
Цитата Сообщение от Leddau Посмотреть сообщение
с максимальной точностью
максимальная точность double 15-17 десятичных разрядов
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
10.04.2019, 20:27
Leddau, ну, чтобы разобраться, какой конкретно байт в восьмибайтовом double за что отвечает мне тоже пришлось немного погуглить.
Без гугла я твёрдо знаю одно. Дробные числа хранятся как порядок(12 бит) и мантисса (6 с половиной байт).
А что это означает?
Ну, если провести аналогию с десятичными дробями (дабл ясен пень - дроби двоичные, а не десятичные)
то это значит, что мы можем хранить числа вида
1,2345 умножить на 10 в степени N

и понятно, что в таком формате,
число 0,0012345 равно 1,2345*10 в минус третьей
число 1234,5 равно 1,2345*10 в третьей
в первом числе сохранилось 7 знаков после запятой, во втором всего лишь один.

То есть количество знаков после запятой напрямую зависит от того, насколько большое по модулю само число.
А не от того, сколько сказали печатать в setprecision
Ты ему скажи напечатать условные 1234,5 из примера с точностью 45 знаков,
он тебе и напишет 12345,мусормусормусормусор

Добавлено через 1 минуту
zayats80888, я только что об этом распинался. числа float и double дословно переводятся как "плавающие"
для них бессмысленно слово "17 разрядов"

Остаётся только добавить, что если бы дроби в компьютере хранились не двоичные, а десятичные, 45 знаков в хвосте дроби и правда заполнялись бы нулями, и было бы не так страшно,
но по факту все дроби в дабл кратны не тысячным и миллионным дробям как в десятичной системе, а одной второй, одной четвёртой, 1/8, 1/16...
поэтому хвостик дроби заполняется не нулями, а например какой-нибудь 1/1024=0,0009765625

Добавлено через 3 часа 3 минуты
вот пример того как изменяется погрешность чисел с плавающей точкой, в зависимости от порядка числа
для примера я взял несколько больших и малых чисел и ншёл, какое число идёт "следующим по счёту" в типе double
C++
1
2
3
//   0.500000000000000111
//  64.000000000000014210
//1024.000000000000227373
как видим, чем больше число, тем меньше его точность.
Очень большие числа типа 10 в 10й, 20й, 30й степени тоже могут влезть в тип double спокойно. Но при этом жертвуются значащие цифры не после, а даже до запятой
C++
1
2
3
4
double x = 1e16;
    x += 1;
    std::cout.precision(48);//хотим увидеть 10000000000000001
    std::cout << x << std::endl;//но видим, как ни странно,10000000000000000
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.04.2019, 20:27
Помогаю со студенческими работами здесь

Вывод n знаков после запятой
Как это сделать?

Google Charts вывод знаков после запятой
Добрый день. Учусь рисовать графики с помощью Google Charts исходники прям у них можно сказать беру...

Вывод двух знаков после запятой в jTextField
Всем добрый день! Подскажите пожалуйста как можно вывести два знака после запятой в jTextField. К примеру есть: double n = 1.254789; ...

Округление числа до 2 знаков после запятой
Буду очень признательна, если кто-то подскажет, как написать программу, округляющую число до двух знаков после запятой. Программа должна...

увеличение числа знаков после запятой
я объявляю два числа a и b как float: float a; float b; потом ввожу b и совершаю следующую операцию: b=1/float(a); после запятой...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru