2011-gre-cs-practice-book.pdf/Q19 — различия между версиями

Материал из DISCOPAL
Перейти к: навигация, поиск
 
(не показано 8 промежуточных версий 1 участника)
Строка 1: Строка 1:
{{reserve-task|[[Участник:Urmat A|Urmat A]] 18:39, 18 декабря 2024 (UTC)}}
 
 
== Вопрос: Q19-08c765 ==
 
== Вопрос: Q19-08c765 ==
 
Пусть все переменные целые и m >= 1.
 
Пусть все переменные целые и m >= 1.
  
 
Псевдокод 1:
 
Псевдокод 1:
<source>
+
<code-pascal>
 
sum = 0
 
sum = 0
 
for i = 1 to m
 
for i = 1 to m
sum = sum + i
+
  sum = sum + i
 
output ( sum )  
 
output ( sum )  
</source>
+
</code-pascal>
  
 
Следующий псевдокод должен выполнять то же самое:
 
Следующий псевдокод должен выполнять то же самое:
 +
 
Псевдокод 2:
 
Псевдокод 2:
<source>
+
<code-c>
 
sum = 0
 
sum = 0
 
i = <initial value>
 
i = <initial value>
Строка 22: Строка 22:
 
}
 
}
 
output ( sum )
 
output ( sum )
</source>
+
</code-c>
  
 
=== Ответы ===
 
=== Ответы ===
 
При каких значениях <initial_value> и <condition>, псевдокод 1 выдаст то же самое, что и псевдокод 2?
 
При каких значениях <initial_value> и <condition>, псевдокод 1 выдаст то же самое, что и псевдокод 2?
#0 i<m-1
+
* 0 и i < m-1
#0 i<m
+
* Правильный ответ: 0 и i < m
#0 i<m+1
+
* 0 и i < m+1
#1 i<m
+
* 1 и i < m
#1 i<m+1
+
* 1 и i < m+1
  
  
 
=== Объяснение ===
 
=== Объяснение ===
<i>Сначала заполните номер страницы с этим вопросом
+
{{cstest-source|2011-gre-cs-practice-book.pdf|24|19}}
{{cstest-source|2011-gre-cs-practice-book.pdf|тут-номер-страницы-с-вопросом-19|19}}
+
 
+
Если все сделаете правильно, по ссылке выше будет открываться правильная страница в правильном PDFе.
+
 
+
Ну и наконец, вики-разметкой напишите ваше понимание, почему правильный ответ — правильный, а [[2004-gre-cs-practice-book.pdf/Q16|неправильные варианты — неправильны]].
+
Тут тоже могут быть полезны [[2004-gre-cs-practice-book.pdf/Q03|ссылки на википедию]],
+
решение вами [[2004-gre-cs-practice-book.pdf/Q12|рекуррентных уравнений в sympy]].
+
  
</i>
+
Можно понять, что в первом коде sum = 1 + 2 + ... + m.
 +
* Чтобы было то же самое, пусть i = 0.
 +
* Тогда в коде на первой итериции i = i + 1, и sum = 0 + 1.
 +
* И пусть i < m, тогда на последней итерации i равно m-1, i = i + 1, то есть i равно m. И sum = sum + m.
 +
{{question-ok|[[Участник:StasFomin|StasFomin]] 21:11, 18 декабря 2024 (UTC)}}
  
{{question-ok|}}
+
[[Категория:Циклы]]

Текущая версия на 21:11, 18 декабря 2024

Вопрос: Q19-08c765

Пусть все переменные целые и m >= 1.

Псевдокод 1:

sum = 0
for i = 1 to m
   sum = sum + i
output ( sum ) 

Следующий псевдокод должен выполнять то же самое:

Псевдокод 2:

sum = 0
i = <initial value>
while ( <condition> )
{
 i = i + 1
 sum = sum + i
}
output ( sum )

Ответы

При каких значениях <initial_value> и <condition>, псевдокод 1 выдаст то же самое, что и псевдокод 2?

  • 0 и i < m-1
  • Правильный ответ: 0 и i < m
  • 0 и i < m+1
  • 1 и i < m
  • 1 и i < m+1


Объяснение

Исходники — вопрос 19 на 24 странице книги «2011-gre-cs-practice-book.pdf»

Можно понять, что в первом коде sum = 1 + 2 + ... + m.

  • Чтобы было то же самое, пусть i = 0.
  • Тогда в коде на первой итериции i = i + 1, и sum = 0 + 1.
  • И пусть i < m, тогда на последней итерации i равно m-1, i = i + 1, то есть i равно m. И sum = sum + m.