IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Конвертор
nik.bstu
сообщение 2.03.2006 20:56
Сообщение #1





Группа: Пользователи
Сообщений: 5
Пол: Мужской

Репутация: -  0  +


Есть мной написанный конвертор числа в двоичный код... Как его можно ускорить... Нужно для ускорения полнопереборных лгоритмов...
const n=15;
type t_kod=array[1..n] of 0..1;
procedure convertor(var a:t_kod; y:longint );
var t:longint;
x,q: longint;

begin
t:=n;
x:=y;
if x<0 then a[1]:= 1;
x:=abs(x);
repeat
q:=x mod 2;
a[t]:=q;
x:= x div 2;
t:=t-1;
until (x=0) or (t = 1);
end;


Тегами пользуйся...

Сообщение отредактировано: volvo - 2.03.2006 20:58
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
volvo
сообщение 2.03.2006 21:14
Сообщение #2


Гость






klem4, а ты приведенную программу ВНИМАТЕЛЬНО смотрел? Уверен, что в FAQ-е есть аналог?

nik.bstu, заменять div 2 на shr 1 (будет быстрее), t := t-1 на dec(t) (тоже быстрее), избавляемся от лишней переменной...
Вот результат:
procedure convertor(var a:t_kod; y:longint );
var
t: longint;
x: longint;
begin
t := n; x := y;
if x<0 then a[1]:= 1;
x := abs(x);
repeat
a[t] := x and $1;
x := x shr 1;
dec(t);
until (x = 0) or (t = 1);

end;

Ну, и естественно, НЕ переусердствуй заранее, решай проблемы по мере появления, ибо "Premature optimization is the root of all evil..." ©
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 18.06.2025 19:13
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"