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

Как преобразовать число float в int без потери данных?

23.02.2016, 15:48. Показов 12566. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, форумчане. Столкнулась с такой проблемой: для работы программы требуется целое число, но вводится число типа float. Так вот, нужно преобразовать число float так, чтобы не потерять дробную часть, т.е. чтобы компьютер читал float-е число как int-е.
Есть строчка: int a = *((int*)&x);
Так это преобразование можно сделать?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.02.2016, 15:48
Ответы с готовыми решениями:

Преобразовать тип данных поля INT в FLOAT
День добрый. Подскажите как сделать преобразование поля, у меня на сервере есть таблица "Оплата" с полем Сумма ( Тип...

преобразовать из wchar_t в char без потери данных
Добрый день, как преобразовать из wchar_t в char без потери данных?

Преобразовать 2 числа int в 1 число float(double) | double int1.int2
Всем привет. Изучая азы C++, столкнулся с такой проблемой. Есть два значения типа int, их необходимо преобразовать в одно значение типа...

8
 Аватар для HighPredator
6045 / 2160 / 753
Регистрация: 10.12.2010
Сообщений: 6,005
Записей в блоге: 3
23.02.2016, 18:22
Вы понимаете физический смысл сего? Как вы себе представляете внедрение дробной части в целое?
0
0 / 0 / 0
Регистрация: 23.02.2016
Сообщений: 11
23.02.2016, 19:41  [ТС]
Я понимаю, что это невозможно, но задание такого: нужно перевести дробное число в двоичную систему с помощью битовой маски.
0
 Аватар для HighPredator
6045 / 2160 / 753
Регистрация: 10.12.2010
Сообщений: 6,005
Записей в блоге: 3
23.02.2016, 19:49
Вы понимаете, что
Цитата Сообщение от grakatine97 Посмотреть сообщение
преобразовать число float так, чтобы не потерять дробную часть, т.е. чтобы компьютер читал float-е число как int-е
не то же самое что и
Цитата Сообщение от grakatine97 Посмотреть сообщение
перевести дробное число в двоичную систему с помощью битовой маски
?

Кстати, а вы часом не тот же автор Число float перевести в двоичный код (с помощью битовой маски) и обратно ?
0
0 / 0 / 0
Регистрация: 23.02.2016
Сообщений: 11
23.02.2016, 19:54  [ТС]
Но битовую маску можно применять только к int и char, а что же тогда делать с float. Вот и была надежда, что можно как-то преобразовать.
Неееет.
0
 Аватар для HighPredator
6045 / 2160 / 753
Регистрация: 10.12.2010
Сообщений: 6,005
Записей в блоге: 3
24.02.2016, 11:21
Ну можно сделать не очень красивую с т.з. стандарта вещь:
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
#include <stdio.h>
 
void GetSME(const float f, int* const s, int* const m, int* const e)
{
  unsigned int* ptr = (unsigned int*) &f;
  
  *s = *ptr >> 31;
  *e = *ptr & 0x7F800000;
  *e >>= 23;
  *m = *ptr & 0x007FFFFF;
}
 
int main(void)
{
  int s, m, e;
 
  float f = 14.42f;
 
  GetSME(f, &s, &m, &e);
 
  printf("%d %d %d\n", s, m, e);
 
  return 0;
}
Работать будет только там, где инт и флоат одного размера. Что в общем не особо гарантируется.
0
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
24.02.2016, 12:13
grakatine97, При чем здесь битовая маска? Дробное число в любую с/с переводится в 2 приема. Отдельно целая часть. И отдельно - дробная. И алгоритмы там разные.
Можно, правда, умножить float-число на 2k (k - требуемая двоичная точность), перевести результат в целое, перевести это целое в двоичную и поставить точку за к-тым (с конца) знаком.
Перевод можно делать стандартно как для любых с/с (с помощью / - %). А в двоичном случае, да, можно воспользоваться битовой техникой. Т.к. взятие остатка от деления на 2 эквивалентно выделению последнего бита, а деление на 2 - сдвигу на 1 позицию. Но все это только для целых (int, short, long) типов!
0
 Аватар для HighPredator
6045 / 2160 / 753
Регистрация: 10.12.2010
Сообщений: 6,005
Записей в блоге: 3
24.02.2016, 13:12
Байт, мне начинает казаться, что имелось ввиду как раз то, что я сделал. А именно: выделение знака, экспоненты и мантиссы из числа по маскам, затем перевод этого в таком порядке в двоичную сс. Есть слухи, что такой разбор идеологически более правилен.
1
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
24.02.2016, 18:07
Цитата Сообщение от HighPredator Посмотреть сообщение
что имелось ввиду как раз то, что я сделал.
Вполне возможно. Задание мутное. Чтоб его понять, надо знать контекст. Что именно они там изучают. Но контекст до нас не донес ТС. И мы вправе предполагать его любым.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.02.2016, 18:07
Помогаю со студенческими работами здесь

Как преобразовать число типа int в строку типа string без методов-конвертов на C#?
В общем, все что выше написано. Пишу в Visual Studio на C#. Преобразовать без конвертирования, например, дано int, дано string, и это число...

Как преобразовать все int,float,double в строки LPWSTR, LPCTSTR
Столкнулся с проблемой не как не переведу в нормальный вид вот код #include &lt;iostream&gt; #include &lt;Windows.h&gt; ...

Как преобразовать документ Word в JPG без потери качества?
Доброго времени суток, у меня следующий вопрос, подскажите пожалуйста: Как фрагмент документа Word (или целую страницу) преобразовать...

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

Не удается преобразовать тип float в int
Так и не могу найти проблему при объявлении массива float (ошибка 6 строчка), а при значении типа double не выводит в консоль ответ. ...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru