Условный оператор не использовать |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
Условный оператор не использовать |
Shullermaster |
Сообщение
#1
|
АдЫн ЭсНеГ Группа: Пользователи Сообщений: 2 Пол: Мужской Реальное имя: Сергей Репутация: 0 |
Помогите, пожалуста, решить задачу. Третий день сижу и ничего не приходит на ум.
Даны 2 натуральных числа m и n, (m,n<1000, m<>n). Если сумма цифр в десятичной записи числа m больше суммы цифр в десятичной записи числа n, вывести на печать разность m и n, в противоположном случае их сумму. Указание: Условный оператор не использовать. -------------------- Опыт - это когда на смену вопросам что? где? когда? как? и почему? приходит единственный вопрос на**я.
|
andriano |
Сообщение
#2
|
Гуру Группа: Пользователи Сообщений: 1 168 Пол: Мужской Реальное имя: Сергей Андрианов Репутация: 28 |
Несмотря на некоторую искусственность условия, оно, тем не менее, имеет большой практический смысл, как только речь заходит о скорости исполнения программы.
1. На современных суперскалярных процессорах неверно предсказанный условный переход выполняется существенно дольше большинства арифметических операций. 2. При использовании SIMD (векторных) инструкций вполне может оказаться, что для части компонент вектора условие выполняется, а для других - нет. Поэтому, если планируется использование MMX, SSE/SSE2/SSE3... возникает необходимость переписать алгоритм так, чтобы он не содержал условных переходов. Наиболее простым способом реализации является следующий: 1. Вычисляется нужное условие и присваивается логической переменной. 2. Эта переменная преобразуется к нужному виду, например, числа или вектора. 3. Вычисляется нужное выражение для КАЖДОЙ из веток условия. 4. Вычисленные выражения домножаются на соответствующие преобразованные логические переменные и произведения складываются. Примерно так: заменняем на c := byte(a > b))*3 + byte(not (a > b))*5; |
Текстовая версия | 11.01.2025 4:20 |