Помощь - Поиск - Пользователи - Календарь
Полная версия: Условный оператор не использовать
Форум «Всё о Паскале» > Pascal, Object Pascal > Задачи
Shullermaster
Помогите, пожалуста, решить задачу. Третий день сижу и ничего не приходит на ум.

Даны 2 натуральных числа m и n, (m,n<1000, m<>n). Если сумма цифр в десятичной записи числа m больше суммы цифр в десятичной записи числа n, вывести на печать разность m и n, в противоположном случае их сумму. Указание: Условный оператор не использовать.
andriano
Несмотря на некоторую искусственность условия, оно, тем не менее, имеет большой практический смысл, как только речь заходит о скорости исполнения программы.
1. На современных суперскалярных процессорах неверно предсказанный условный переход выполняется существенно дольше большинства арифметических операций.
2. При использовании SIMD (векторных) инструкций вполне может оказаться, что для части компонент вектора условие выполняется, а для других - нет. Поэтому, если планируется использование MMX, SSE/SSE2/SSE3... возникает необходимость переписать алгоритм так, чтобы он не содержал условных переходов.

Наиболее простым способом реализации является следующий:
1. Вычисляется нужное условие и присваивается логической переменной.
2. Эта переменная преобразуется к нужному виду, например, числа или вектора.
3. Вычисляется нужное выражение для КАЖДОЙ из веток условия.
4. Вычисленные выражения домножаются на соответствующие преобразованные логические переменные и произведения складываются.
Примерно так:

if a > b then
c := 3
else
c := 5;
заменняем на
c := byte(a > b))*3 + byte(not (a > b))*5;
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.