Версия для печати темы

Нажмите сюда для просмотра этой темы в обычном формате

Форум «Всё о Паскале» _ Задачи _ Условный оператор не использовать

Автор: Shullermaster 12.11.2009 14:36

Помогите, пожалуста, решить задачу. Третий день сижу и ничего не приходит на ум.

Даны 2 натуральных числа m и n, (m,n<1000, m<>n). Если сумма цифр в десятичной записи числа m больше суммы цифр в десятичной записи числа n, вывести на печать разность m и n, в противоположном случае их сумму. Указание: Условный оператор не использовать.

Автор: andriano 12.11.2009 16:33

Несмотря на некоторую искусственность условия, оно, тем не менее, имеет большой практический смысл, как только речь заходит о скорости исполнения программы.
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;