Форум программистов, компьютерный форум CyberForum.ru

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

Войти
Регистрация
Восстановить пароль
 
 
Klochkov Alexey
Сообщений: n/a
#1

Неверное значение числа после операций над ним - C++

15.07.2013, 01:45. Просмотров 550. Ответов 16
Метки нет (Все метки)

Всем привет. Прошу помощи! Я использую g++ компилятор.
Итак, проблема:
После того, как я умножаю вещественное число типа float, например 0.123, на 10000000, должно получится 1230000, но у меня почему-то получается 1230001! В чем подвох? Объясните пожалуйста.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.07.2013, 01:45     Неверное значение числа после операций над ним
Посмотрите здесь:

Найти исходное число после выполненных над ним операций - C++
#include <iostream> #include <conio.h> using namespace std; class Num { int x1; int x2; int x; int n = 0;

Определите значение значений всех переменных после выполнения операций - C++
2. Определите значение значений всех переменных после выполнения операций: a=-1 b=1 d=a+++2-(--b); c=a+1+(--d);

Массив строк и действия над ним - C++
Вводится массив строк символов. Необходимо найти самую длинную строку, и увеличить все строки остальные до ее размеров используя символ...

Перегрузка операций над матрицами - C++
Создать динамический класс для работы с матрицами. Считать, что компоненты имеют целый тип. Осуществить перегрузки символов операций: ...

Формирование случайного массива и действия над ним - C++
Сформировать случайным образом массив из 20 элементов. Найти максимальный и минимальный элементы массива, поменять их местами и вычислить...

Методы реализации операций над текстом - C++
Не совсем понятны мне алгоритмы, как реализовать такие операции над текстом:

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Genn55
366 / 213 / 41
Регистрация: 26.12.2012
Сообщений: 707
15.07.2013, 02:45     Неверное значение числа после операций над ним #2
Попробуйте
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include<iostream>
#include <iomanip>
 
using namespace std;
 
int main()
{
 
float N,m;
 cout << "Enter N " << "\n";
 cin >>N;
 m = N *10000000;
cout<< setw(8) << setprecision(3) << setiosflags (ios::fixed | ios::showpoint)<< m<<"\n";
return 0;
}
Добавлено через 3 минуты
А при таких вычислениях лучше использовать
C++
1
double
ошибок не будет.
SatanaXIII
Супер-модератор
Эксперт С++
5603 / 2637 / 242
Регистрация: 01.11.2011
Сообщений: 6,496
Завершенные тесты: 1
15.07.2013, 10:34     Неверное значение числа после операций над ним #3
Klochkov Alexey, почитайте о представлении чисел с плавающей точкой.
Klochkov Alexey
Сообщений: n/a
15.07.2013, 12:23     Неверное значение числа после операций над ним #4
Большое спасибо, попробую, потом еще отпишусь!

Добавлено через 48 секунд
Спасибо, полезная ссылка... Обязательно прочту!
Tulosba
:)
Эксперт С++
4393 / 3236 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
15.07.2013, 12:28     Неверное значение числа после операций над ним #5
Цитата Сообщение от Genn55 Посмотреть сообщение
А при таких вычислениях лучше использовать double ошибок не будет
Ошибки как были, так и будут. Просто точность изменится.
Genn55
366 / 213 / 41
Регистрация: 26.12.2012
Сообщений: 707
15.07.2013, 12:40     Неверное значение числа после операций над ним #6
Все в мире относительно и абсолютной точности добиться не возможно,но есть пределы разумного и не обходимого.Я не раз сталкивался в с++ 0 вовсе и не 0,а какое то очень маленькое число.С типом float ошибка будет происходить намного раньше,чем с типом double.Это сугубо мое мнение,все равно мнения у разных авторов расходятся.
Tulosba
:)
Эксперт С++
4393 / 3236 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
15.07.2013, 12:46     Неверное значение числа после операций над ним #7
Цитата Сообщение от Genn55 Посмотреть сообщение
Все в мире относительно и абсолютной точности добиться не возможно
Почему же, используйте числа с фиксированной запятой.
Цитата Сообщение от Genn55 Посмотреть сообщение
Я не раз сталкивался в с++ 0 вовсе и не 0,а какое то очень маленькое число.
Значит это и был не 0 изначально.
Genn55
366 / 213 / 41
Регистрация: 26.12.2012
Сообщений: 707
15.07.2013, 13:00     Неверное значение числа после операций над ним #8
Цитата Сообщение от Tulosba Посмотреть сообщение
Почему же, используйте числа с фиксированной запятой.
Это как?

Добавлено через 1 минуту
Если можно простенький пример.
Tulosba
:)
Эксперт С++
4393 / 3236 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
15.07.2013, 13:02     Неверное значение числа после операций над ним #9
Цитата Сообщение от Genn55 Посмотреть сообщение
Это как?
Это когда в основе лежит целое.

Не по теме:

Use google, Luke.

Genn55
366 / 213 / 41
Регистрация: 26.12.2012
Сообщений: 707
15.07.2013, 13:08     Неверное значение числа после операций над ним #10
Т.е все расчеты вести с целыми числами,а затем перевести с плавающей?
Tulosba
:)
Эксперт С++
4393 / 3236 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
15.07.2013, 13:36     Неверное значение числа после операций над ним #11
Цитата Сообщение от Genn55 Посмотреть сообщение
Т.е все расчеты вести с целыми числами,а затем перевести с плавающей?
Переводить не надо. Достаточно просто отображать должным образом.
Genn55
366 / 213 / 41
Регистрация: 26.12.2012
Сообщений: 707
15.07.2013, 13:42     Неверное значение числа после операций над ним #12
Простенький примерчик можно?Мне эта тема интересна.А мнения у всех разные.Возможно я вас не правильно пойму,а на примере быстрее соображу.
Tulosba
:)
Эксперт С++
4393 / 3236 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
15.07.2013, 14:14     Неверное значение числа после операций над ним #13
Цитата Сообщение от Genn55 Посмотреть сообщение
Простенький примерчик можно?
вики посмотрите.
Genn55
366 / 213 / 41
Регистрация: 26.12.2012
Сообщений: 707
15.07.2013, 15:48     Неверное значение числа после операций над ним #14
Чем хуже такое представление?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iomanip>
#include <iostream>
using namespace std;
 
int main()
{
    double arr[] = {0.25, -12e-110, 25,25e-6,25e-3};
    for (int i = 0; i<5; i++)
    cout<< setw(8) <<arr[i]<<"\n";
    cout<<"\n\n";
    for (int i = 0; i<5; i++)
    cout<< setw(110) << setprecision(110) << setiosflags (ios::fixed | ios::showpoint)<< arr[i]<<"\n";
    cout<<"\n\n";
    for (int i = 0; i<5; i++)
    cout<<scientific<<arr[i]<<"\n";
    return 0;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.07.2013, 16:48     Неверное значение числа после операций над ним
Еще ссылки по теме:

Перегрузка операций над 16-ричными числами - C++
Базовый класс «Шестнадцатеричное число»: - конструкторы (по умолчанию, инициализация пользователем); - методы доступа; - метод вывода...

Программа для операций над битами - C++
Здравствуйте, товарищи программисты! Прошу вас помочь мне с одним делом. В книге есть описание работы с битами. там есть умножение,...

Программа основных операций над матрицами - C++
Помогите пожалуйста, нужно написать программу основных операций над матрицами в С++ Транспортировку сделала, дальше всё никак+это ведь...

Связный список (создать и реализовать операции над ним) - C++
Помогите, пожалуйста, доделать задание. Мне нужно создать связный список и реализовать операции над ним. 1. Создание списка из файла. ...


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

Или воспользуйтесь поиском по форуму:
Tulosba
:)
Эксперт С++
4393 / 3236 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
15.07.2013, 16:48     Неверное значение числа после операций над ним #15
Цитата Сообщение от Genn55 Посмотреть сообщение
Чем хуже такое представление?
Не понял Вашего вопроса.
Yandex
Объявления
15.07.2013, 16:48     Неверное значение числа после операций над ним
Ответ Создать тему
Опции темы

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