С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.53/15: Рейтинг темы: голосов - 15, средняя оценка - 4.53
1 / 1 / 0
Регистрация: 25.09.2015
Сообщений: 25
1

Результат преобразования int в float

24.10.2015, 17:12. Показов 2911. Ответов 31
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброго времени суток,пример
C++
1
2
3
4
5
6
7
8
9
10
unsigned int sande1=0,sande2=0;
 
 void TForm1::mat_tt(){
  float dat=0.0;
  int posred=0;
    posred=(256*sande1)+sande2;
   //dat=(float)((256*sande1)+sande2)/10;
   dat=(float)posred/10;
   Label1->Caption=FloatToStr(dat);
}
по коду видно что переменную posred делю на 10 получаю переменную типа float.
Вопрос в том что,по математике, при делении целого числа на 10, получается значение с одним знаком после запятой,а у меня иногда выводит больше чем один. Как так,что сделать?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
24.10.2015, 17:12
Ответы с готовыми решениями:

ОШИБКА [Error] cannot convert 'int*' to 'float*' for argument '1' to 'void Syma(float*,int*,int)
Какая то проблема с указателями,незнаю,не хочет щитать суму парних чисел в второй...

Неверный результат при преобразования типов данных static_cast<int>(double)
Доброго времени суток, уважаемые программисты! Перейду сразу к сути проблемы: При данном значении...

Функции float average(int arrray[],int from,int to)
Напишите код функции float average(int arrray,int from,int to). Возвращаемым значением функции...

Чем отличаются float преобразования (float)var от float(var)
Здравствуйте! Подскажите, чем отличается (float)var от float(var)

31
7803 / 6567 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
24.10.2015, 17:15 2
Во-первых, не используй древний тип float, только double. Во-вторых, у вещественных форматов есть погрешность представления. Это нормально.
0
1 / 1 / 0
Регистрация: 25.09.2015
Сообщений: 25
24.10.2015, 17:40  [ТС] 3
Тогда следует другой вопрос, как сократить результат до одного знака после запятой?
0
2549 / 1208 / 358
Регистрация: 30.11.2013
Сообщений: 3,826
24.10.2015, 17:43 4
Цитата Сообщение от nmcf Посмотреть сообщение
древний тип float
почему он древний то?
0
599 / 237 / 69
Регистрация: 08.08.2015
Сообщений: 1,637
24.10.2015, 17:49 5
rikimaru2013, Ну он наверно имеет ввиду допуск к памяти
nmcf, Не путай человека, не следует использовать более "тяжелые" типы данных если хватает менее затратных. Это равносильно как убивать комара кувалдой!
0
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,169
Записей в блоге: 10
24.10.2015, 18:01 6
Цитата Сообщение от Mesteriis Посмотреть сообщение
rikimaru2013, Ну он наверно имеет ввиду допуск к памяти
А что не так с допуском к памяти у float?

Добавлено через 4 минуты
Цитата Сообщение от nmcf Посмотреть сообщение
Во-первых, не используй древний тип float, только double.
Зачем такое советовать?
Это разные типы, у них разные размеры и разная точность, и скорость работы с float будет гарантировано не более (если, конечно, это не эмуляция) чем с работой с double.
Некоторые люди даже специально вводят half_float (16 бит) для своих нужд. Этого говорит о том что выбирать вещественный тип необходимо от потребности, и востребованы бывают все.
0
599 / 237 / 69
Регистрация: 08.08.2015
Сообщений: 1,637
24.10.2015, 18:02 7
castaway, Да все там хорошо, но если вспомнить спецификацию к типам данных то double равен или больше float. Соответственно может кушать больше памяти. Если хватает float то зачем нагромождать!
0
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,169
Записей в блоге: 10
24.10.2015, 18:03 8
Цитата Сообщение от Mesteriis Посмотреть сообщение
Если хватает float то зачем нагромождать!
Ну так и я об этом.
0
Mesteriis
24.10.2015, 18:08
  #9

Не по теме:

castaway, Ну вот, я даже помню у нас учитель информатики говорил что вместо int пишите всегда long а то вдруг что))) даже бал снижал за использования int))), после этого я все понял о качестве нашего теперешнего образования!

0
1 / 1 / 0
Регистрация: 25.09.2015
Сообщений: 25
24.10.2015, 18:32  [ТС] 10
Цитата Сообщение от ticlir Посмотреть сообщение
Тогда следует другой вопрос, как сократить результат до одного знака после запятой?
Извините, как округлить до одного знака после запятой?
0
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,169
Записей в блоге: 10
24.10.2015, 18:35 11
Цитата Сообщение от ticlir Посмотреть сообщение
Извините, как округлить до одного знака после запятой?
C++
1
2
3
4
5
6
#include <iostream>
 
int main() {
    double f = 123.456;
    std::cout << int(f * 10) / 10. << std::endl;
}
0
1 / 1 / 0
Регистрация: 25.09.2015
Сообщений: 25
24.10.2015, 19:02  [ТС] 12
Цитата Сообщение от castaway Посмотреть сообщение
std::cout << int(f * 10) / 10. << std::endl;
Builder6 ругается, я говорит такого не знаю.
0
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,169
Записей в блоге: 10
24.10.2015, 19:03 13
Цитата Сообщение от ticlir Посмотреть сообщение
Builder6 ругается, я говорит такого не знаю.
Такого - это какого? Чего именно он не знает? Эта конструкция должна работать даже на древнем Borland C++ под DOS.
0
1 / 1 / 0
Регистрация: 25.09.2015
Сообщений: 25
24.10.2015, 19:23  [ТС] 14
[C++ Error] myPR_cpp.cpp(139): E2316 'cout' is not a member of 'std'
[C++ Error] myPR_cpp.cpp(139): E2316 'endl' is not a member of 'std'
Вот реакция на код..
0
Эксперт С++
4986 / 3093 / 456
Регистрация: 10.11.2010
Сообщений: 11,169
Записей в блоге: 10
24.10.2015, 19:24 15
ticlir,
C++
1
#include <iostream>
0
1 / 1 / 0
Регистрация: 25.09.2015
Сообщений: 25
24.10.2015, 19:30  [ТС] 16
Вот теперь всё работает. Спасибо.
0
7803 / 6567 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
24.10.2015, 21:01 17
Цитата Сообщение от rikimaru2013 Посмотреть сообщение
почему он древний то?
Потому что его любили в старых книжках.
Цитата Сообщение от Mesteriis Посмотреть сообщение
не следует использовать более "тяжелые" типы данных если хватает менее затратных
Какой сейчас год? О каких затратах речь? double - базовый вещественный тип, предложите ещё short вместо int использовать - для экономии.
0
1943 / 1768 / 825
Регистрация: 23.01.2014
Сообщений: 6,230
24.10.2015, 21:18 18
Неправильно, наверное, говорить старый тип или новый. Мощные сейчас компьютеры или не мощные. Если Вам нужно передать по сети 1000000 значений в секунду с плавающей запятой, но Вам не нужна точность более чем 3 знака после запятой, то есть все-таки смысл использовать float - сэкономите ни много ни мало почти что 1 мБ трафика в секунду.

Второй пример, int (4-х байтный) - самый распространенный тип данных для хранения целочисленных данных. Float же удобен тем, что занимает также 4 байта. Это очень удобно и используется в протоколах передачи данных.

Все типы нужны в каких-то конкретных случаях. С тем же успехом можно сказать "зачем тебе bool, он устарел, используй double". Тем более человек только учится...
0
7803 / 6567 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
24.10.2015, 22:13 19
Он ничего по сети не передаёт, и ничего не сэкономит.
int cамый распространённый? Как ты это определил? Совсем недавно он 16-битным был.
0
Модератор
Эксперт по электронике
8950 / 6716 / 921
Регистрация: 14.02.2011
Сообщений: 23,708
24.10.2015, 22:24 20
float хорош когда нет сопроцессора
тогда он занимает 4 байта, библиотеки меньше
но в когда он запихивается в сопроцессор, то растягивается до double(8 байт) а то и long double(10 байт)
так что, что использовать нужно каждый раз решать в зависимости от задачи

Добавлено через 1 минуту
Цитата Сообщение от nmcf Посмотреть сообщение
Как ты это определил? Совсем недавно он 16-битным был.
когда процессоры 16 битные были

правда когда пошли 64 битные, то int 64 бита не сделали

Добавлено через 1 минуту
Цитата Сообщение от pav1uxa Посмотреть сообщение
"зачем тебе bool, он устарел, используй double".
интересное заявление
bool один из самых молодых типов, а во вторых что между ними общего?
0
24.10.2015, 22:24
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
24.10.2015, 22:24
Помогаю со студенческими работами здесь

Ошибка преобразования float в float*
Выдает ошибку невозможности преобразование /main.cpp/ #include &lt;iostream&gt; #include &quot;gkh.h&quot; int...

Почему при умножении разнотипных переменных (например, float и int) получается int?
Почему при умножении разнотипных переменных (float price и int unit) получается int? Это же не...

Как происходит преобразование int<<float<int
Как происходит преобразование int&lt;&lt;float&lt;int int n=222222222; float f=(float)n; n=(int)f;...

Если результат деления int на int есть тип float
Есть две ситуации: int a = 10; int b = 3; c = a/b; // через несколько строчек тоже самое но...

Перевод Int/FLoat -> QByteArray -> Int/Float
Есть задача переводить float/int данные в бинарный вид и обратно (в последующем для передачи по...

КВИТАНЦИЯ (номер – int, дата – int, сумма – float)
Помоги решить пожалуйста лабораторную работу, 13 варианта, буду очень признателен! очень срочно !


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru