[an error occurred while processing this directive]
Взял я с того, что не быстрый алгоритм я могу предложить (+)
(«Телесистемы»: Конференция «Микроконтроллеры и их применение»)

миниатюрный аудио-видеорекордер mAVR

Отправлено an2an 22 декабря 2005 г. 13:08
В ответ на: в принципе, если точность примерно до пола, сначала дели потом умножай, иначе с чего ты взял что можно? отправлено <font color=gray>vvv</font> 21 декабря 2005 г. 23:33

Представим себе что
А*B = A+A+A+...+A B раз
и если D=(A*B)/С, то (A*B)-C-C-...-C D раз есть ноль (без учета остатка)

Теперь алгоритм:

D=0;
AB=0;
for(i=0; i AB += A;
if (AB >= C) {
AB -= C;
D++;
}
}
В конце имеем ответ в C и остаток в AB, понятно что если A, B и C по 31 биту, то 32 бит хватит...

Составить ответ  |||  Конференция  |||  Архив

Ответы


Отправка ответа

Имя (обязательно): 
Пароль: 
E-mail: 
NoIX ключ Запомнить

Тема (обязательно):
Сообщение:

Ссылка на URL: 
Название ссылки: 

URL изображения: 


Rambler's Top100 Рейтинг@Mail.ru
Перейти к списку ответов  |||  Конференция  |||  Архив  |||  Главная страница  |||  Содержание

E-mail: info@telesys.ru