2001-gre-vs-practice.pdf/Q13 — различия между версиями
Материал из DISCOPAL
StasFomin (обсуждение | вклад) |
|||
Строка 39: | Строка 39: | ||
* 2/4 > 0.001? true -> | * 2/4 > 0.001? true -> | ||
* 2/8 > 0.001? true -> | * 2/8 > 0.001? true -> | ||
− | + | … | |
* 2/2^11 > 0.001? false. | * 2/2^11 > 0.001? false. | ||
− | Итого условие цикла выполнилось 12 раз, следовательно верный | + | Итого условие цикла выполнилось 12 раз, следовательно верный ответ — 10-19. |
− | {{question-ok|}} | + | {{question-ok|[[Участник:StasFomin|StasFomin]] 08:45, 21 декабря 2024 (UTC)}} |
− | + | [[Категория:Циклы]] | |
− | + | ||
− | [[Категория: | + |
Версия 08:45, 21 декабря 2024
Задача зарезервирована: Tiniakov.ad 14:23, 20 декабря 2024 (UTC)
Вопрос: Q13-e5724f
Рассмотрим следующую программу на языке C
#include <stdio.h> void main() { float sum = 0.0, j = 1.0, i = 2.0; while (i / j > 0.001) { j = j + j; sum = sum + i / j; printf("%f\n", sum); } }
Сколько строчек выведет программа?
Ответы
- 0-9;
- Правильный ответ: 10-19;
- 20-29;
- 30-39;
- >39.
Объяснение
Исходники — вопрос 13 на 19 странице книги «2001-gre-vs-practice.pdf»
Данная программа в цикле while проверяет условие i / j > 0.001. Если условие выполнено, она увеличивает j вдвое и выводит на новой строке число. Изначально j == 1.0, i == 2.0. Значит в цикле имеем следующую цепочку проверок:
- 2/1 > 0.001? true ->
- 2/2 > 0.001? true ->
- 2/4 > 0.001? true ->
- 2/8 > 0.001? true ->
…
- 2/2^11 > 0.001? false.
Итого условие цикла выполнилось 12 раз, следовательно верный ответ — 10-19.