2001-gre-vs-practice.pdf/Q14

Материал из DISCOPAL
Перейти к: навигация, поиск

Вопрос: Q14-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;
  • 1;
  • Правильный ответ: 2;
  • 3;
  • 4.

Объяснение

Исходники — вопрос 14 на 19 странице книги «2001-gre-vs-practice.pdf»

Данная программа в цикле while проверяет условие i / j > 0.001. Если условие выполнено, она увеличивает j вдвое, увеличивает сумму на i/j и выводит на новой строке новую сумму. Изначально sum == 0.0, j == 1.0, i == 2.0. Значит в цикле имеем следующую цепочку:

  • 2/1 > 0.001? true -> j *= 2, sum += i/j
  • 2/2 > 0.001? true -> j *= 2, sum += i/j
  • 2/4 > 0.001? true -> j *= 2, sum += i/j
  • 2/8 > 0.001? true -> j *= 2, sum += i/j

...

  • 2/2^11 > 0.001? false.

Итого получаем сумму геометрической прогрессии: 2/2 + 2/4 + 2/8 + ... + 2/2^11 == 1 + 1/2 + 1/4 + ... + 1/2^10. Известный факт, что сумма обратных степеней двойки в пределе равна 1 (). Следовательно, последнее число точно не больше 2. Рассмотрим сумму еще раз: она начинается со слагаемых 1 + 1/2 + 1/4 + ... Это уже больше, чем 1.5, следовательно последняя сумма точно больше 1.5, а значит лучшим приближением для последней суммы будет 2.

[ Хронологический вид ]Комментарии

(нет элементов)

Войдите, чтобы комментировать.