реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> Округлить число до целого в большую сторону
ViKo
сообщение Apr 8 2014, 06:54
Сообщение #1


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



Для стандартного округления, если дробная часть больше 0,5 - к целой части прибавляется 1, можно применить формулу:

(X + (Y / 2)) / Y

Например, 72 / 11
(72 + (11 / 2)) / 11 = 77 / 11 = 7

Если же нужно, чтобы округленное число было не менее того, что округляли, как вычислять?
Например, 72 / 5 = 14.4 = 15
Как-то так:

X / Y + !!(X % Y)

Есть способ иной?
Go to the top of the page
 
+Quote Post
zambezi
сообщение Apr 8 2014, 07:08
Сообщение #2


Частый гость
**

Группа: Участник
Сообщений: 82
Регистрация: 15-03-14
Из: Калуга
Пользователь №: 80 935



Цитата(ViKo @ Apr 8 2014, 10:54) *
Если же нужно, чтобы округленное число было не менее того, что округляли, как вычислять?
Например, 72 / 5 = 14.4 = 15


Отбросить дробную часть и прибавить 1. Или прибавить 0.5 и округлять стандартным способом.
Go to the top of the page
 
+Quote Post
Shamil
сообщение Apr 8 2014, 07:09
Сообщение #3


Частый гость
**

Группа: Свой
Сообщений: 160
Регистрация: 23-12-04
Из: Уфа
Пользователь №: 1 631



Если X и Y целочисленные переменные, то я пишу так:
(X + Y - 1) / Y
Go to the top of the page
 
+Quote Post
ViKo
сообщение Apr 8 2014, 07:24
Сообщение #4


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



Цитата(zambezi @ Apr 8 2014, 10:08) *
Отбросить дробную часть и прибавить 1.

А если делится нацело?

Цитата(Shamil @ Apr 8 2014, 10:09) *
Если X и Y целочисленные переменные, то я пишу так:
(X + Y - 1) / Y

Годится, спасибо!
Go to the top of the page
 
+Quote Post
SM
сообщение Apr 8 2014, 07:36
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 7 946
Регистрация: 25-02-05
Из: Moscow, Russia
Пользователь №: 2 881



стандартный способ:

(((x <<1)/y)+1)>>1)

То есть, считать в формате 14.1 (или 31.1, или 7.1, смотря какая там разрядность), прибавлять 0.5 (в этом формате это число = 1), и потом сдвиг вправо - приведение к формату 15.0
Go to the top of the page
 
+Quote Post
ViKo
сообщение Apr 8 2014, 07:47
Сообщение #6


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



Цитата(SM @ Apr 8 2014, 10:36) *
стандартный способ:

(((x <<1)/y)+1)>>1)

То есть, считать в формате 14.1 (или 31.1, или 7.1, смотря какая там разрядность), прибавлять 0.5 (в этом формате это число = 1), и потом сдвиг вправо - приведение к формату 15.0

Это дает стандартное округление. А нужно округлить до ближайшего не меньшего целого. Если вместо 1 прибавлять 2, то будет неправильно для деления нацело.
Go to the top of the page
 
+Quote Post
SM
сообщение Apr 8 2014, 08:13
Сообщение #7


Гуру
******

Группа: Свой
Сообщений: 7 946
Регистрация: 25-02-05
Из: Moscow, Russia
Пользователь №: 2 881



ну да. сорри, не так вопрос понял.
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 20:19
Рейтинг@Mail.ru


Страница сгенерированна за 0.01389 секунд с 7
ELECTRONIX ©2004-2016