Листинг 2.11. Использование инструкций continue и break

 

#include <iostream>

#include <cmath>

 

using namespace std;

 

int main (void)

{

int n, m;

 

cin >> n >> m;

 

double E = 0;

for (int i = 1; i <= n; i++) {

double P = 1;

 

for (int j = 1; j <= m; j++) {

if (j % 3) //пропуск итерации при ;

continue;

 

P *= j - i;

}

 

E += P;

}

 

cout << E << endl;

 

return 0;

}

 

2.3. Упражнения

2.3.1. Ветвления

Найти решения заданных функций, используя ветвления «if – else», «switch» или условный оператор. Число «x» вводится пользователем с клавиатуры.

 


1.

 

2.

 

3.

 

4.

 

5.

 

6.

 

7.

 

8.

 

9.

 

10.

 

11.

 

12.

 

13.

 

14.

 

15.

 

16.

 

17.

 

18.

 

19.

 

20.

 


 

2.3.2. Циклы

Найти решения заданных функций, используя циклы «for», «while», «do – while». Число «n» вводится пользователем с клавиатуры.

 


1.

 

2.

 

3.

 

4.

 

5.

 

6.

 

7.

 

8.

 

9.

 

10.

 

11.

 

12.

 

13.

 

14.

 

15.

 

16.

 

17.

 

18.

 

19.

 

20.

 


 

2.3.3. Вложенность

Найти решения заданных функций, используя циклы «for», «while», «do – while». Числа «n» и «m» вводятся пользователем с клавиатуры.

 


1 .

 

2 .

 

3 .

 

4 .

 

5 .

 

6 .

 

7 .

 

8 .

 

9 .

 

10 .

 

11 .

 

12 .

 

13 .

 

14 .

 

15 .

16 .

17 .

 

18 .

 

19 .

 

20 .

 


3. Указатели. Массивы. Структуры

Память любого С++ – приложения делится на две части: область «heap» и область «stack». Наглядной абстракцией для представления стека может служить колода карт. Так в стеке верхняя карта – текущая область видимости программы, например, область видимости выполняемой в данный момент функции. В тот момент, когда текущая функция вызывает очередную, то уже новая текущая карта располагается поверх данной, а при завершении ее работы – удаляется. Такие карты часто называют фреймами. Стековые фреймы эффективны для реализации изолированной работы функций. Другая область – «heap» – не зависит от текущего стекового фрейма. В эту область можно поместить и переменные, объявленные в теле функции, с тем, чтобы они существовали после ее завершения («static»). Область «heap» не является структурированной, по этому представима как некоторый набор ячеек памяти.

 

3.1. Указатели

Язык С++ предусматривает два способа выделения памяти для объектов: статическое выделение во время компиляции, и динамическое – во время выполнения программы. Статическое выделение памяти является более эффективным, однако размер того или иного объекта не всегда известен до компиляции, что делает динамическое выделение памяти более гибким.

Реализация указателей происходит посредством встроенного типа, объекты которого хранят адреса других объектов. Указатель объявляется, как указатель на определенный тип, и не может указывать на объекты другого типа. Исключением является «void» – указатель, способный указывать на объекты любого типа. Однако, такие указатели не могут быть разыменованы.

Для работы с указателями необходимы две специальные операции: взятие адреса «&» и разыменование «*», называемое также косвенной адресацией. Результат операции «&» – адрес объекта, а использование «*» позволяет обратиться к значению в памяти, на которую указывает разыменовываемый объект. К числу необходимых для динамического выделения памяти операторов относятся операторы «new» и «delete», аналогичные С – функциям «malloc()» и «free()». Следующий листинг дает первоначальное представление об указателях.

 



/span>7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • Далее ⇒