C++ pętle

Tworzenie pętli w języku C++

Pętla (ang. loop) jest instrukcją złożoną, która pozwala cyklicznie wykonywać zadaną instrukcję języka C++.
Pętla warunkowa
(ang. conditional loop) wykonuje powtarzanie w zależności od określonego warunku (takiego samego jak dla&nbps;instrukcji warunkowej if).
W języku C++ wyróżniamy dwie instrukcje pętli warunkowych:

 

while(warunek) instrukcja;

lub

while(warunek)
{

    ciąg instrukcji
}

Instrukcja wewnątrz pętli jest wykonywana dopóki warunek kontynuacji w instrukcji while jest prawdziwy. Warunek ten jest sprawdzany na początku każdego obiegu. Jeśli będzie fałszywy, to obieg nie zostanie wykonany i program przejdzie do wykonywania dalszej części swojego kodu za instrukcją while. Wynika z tego wniosek, że jeżeli warunek jest fałszywy przy rozpoczęciu wykonywania pętli, to zawarta w niej instrukcja nie zostanie wykonana ani jeden raz.
do instrukcja; while(warunek);

lub

do
{
    ciąg instrukcji
} while(warunek);
Działanie tej pętli jest podobne do powyższej pętli while. Różnica polega jedynie na tym, iż warunek jest tutaj sprawdzany na końcu obiegu. Jeśli będzie prawdziwy, to pętla wykona następny obieg - zostanie powtórzone wykonanie zawartej w niej instrukcji. Jeśli warunek będzie fałszywy, to wykonanie pętli zostanie przerwane i program przejdzie do instrukcji leżących pod pętlą do while. Wynika z tego wniosek, że pętla do while zawsze wykonuje co najmniej jeden obieg.

 

// Kolejne liczby naturalne
// od 1 do granicy g

//------------------------

#include <iostream>

using namespace std;

int main()
{
    unsigned int i,g;

    cin >> g;
    i = 1;

    while(i <= g) cout << i++ << " ";

    cout << endl;
    return 0;
}
// Kolejne liczby naturalne
// od 1 do granicy g

//------------------------

#include <iostream>

using namespace std;

int main()
{
    unsigned int i,g;

    cin >> g;
    i = 1;

    do cout << i++ << " "; while(i <= g); 

    cout << endl;
    return 0;
}

zadania

  1. Wyświetl 10 kolejnych liczb nieparzystych rozpoczynając od liczby wprowadzonej przez użytkownika. Jeżeli użytkownik wprowadzi liczbę parzystą zaczynamy od kolejnej nieparzystej. (void nieparzyste()).
  2. Wyświetl 10 kolejnych liczb parzystych rozpoczynając od liczby wprowadzonej przez użytkownika. Jeżeli użytkownik wprowadzi liczbę nieparzystą zaczynamy od kolejnej parzystej. (void parzyste()).
  3. Wyświetl 10 liczb podzielnych przez 3 rozpoczynając od liczby podanej przez użytkownika (void podzielne3()).
  4. Kolejne 10 potęg liczby 2 (void potegi2()).
  5. Suma kolejnych liczb naturalnych od zera do liczby podanej (int sumy()).
  6. Kolejne liczby Fibonacciego. Ilośc określa użytkownik. (void fibonacci()).
    1, (0+1)=1, (1+1)=2, (1+2)=3, (2+3)=5, (3+5)=8, (5+8)=13,....

Instrukcje break i continue

Instrukcja break natychmiast przerywa wykonywanie pętli. Wykorzystuje się ją w sytuacji, gdy dalsze powtarzanie wykonywania instrukcji w pętli jest z pewnych względów niepożądane.
Instrukcja continue przerywa bieżący obieg pętli i natychmiast rozpoczyna następny obieg. Wykorzystuje się ją w przypadku, gdy wykonywanie instrukcji w bieżącym obiegu jest niepożądane.

 


//------------------------

#include <iostream>

using namespace std;

const int kod = J23;

int main()
{
    int i,c;
    i = 1;

    do
    {
        cout << "WPISZ KOD : ";
        cin >> c;
        if(c == kod) break;
        i++;
    } while(i <= 3);

    if(c == kod)
    {
        cout << "KOD ZAAKCEPTOWANY.\n\n";
        return 0;
    }
    else
    {
        cout << "BRAK AUTORYZACJI.\n\n";
        return 1;
    }
}

Instrukcja pętli iteracyjnej

Obiegi wykonywane przez pętlę można numerować. Obieg numerowany nazywamy iteracją. Iteracja wymaga dodatkowej zmiennej, która przechowuje numer wykonywanego przez pętlę obiegu. Zmienna ta nosi nazwę licznika pętli (ang. loop counter). Pętlę iteracyjną możemy utworzyć przy pomocy poznanych dotychczas pętli warunkowych.

Przykład:

Poniższe pętle wykonują 10 obiegów. Obiegi zliczane są przez zmienną i, która pełni tutaj rolę licznika pętli.

...
i = 1;
while(i <= 10)
{
    cout << i << endl;     
    i++;
}
...
...
i = 1;
do
{
    cout << i << endl;
    i++;
} while(i <= 10);
...

Ponieważ pętle iteracyjne pojawiają się w programach bardzo często, w języku C++ istnieje specjalna instrukcja do ich łatwej realizacji. Składnia tej instrukcji jest następująca:

 

for(prolog; kontynuacja; epilog) instrukcja;

 

lub z instrukcją złożoną:

 

for(prolog; kontynuacja; epilog)
{
   Ciąg instrukcji;
}

 

prolog  -  instrukcja wykonywana przed rozpoczęciem pierwszej iteracji. Najczęściej służy do inicjalizacji licznika pętli.
Przykład:

for(i  = 1;...

kontynuacja  - warunek kontynuacji pętli. Jeśli wyrażenie to ma wartość różną od 0, to pętla wykona obieg. Warunek jest sprawdzany na początku każdej iteracji.
Przykład:

for(i = 1; i <= 10;...

epilog  - instrukcja wykonywana po zakończeniu każdej iteracji. Najczęściej wykorzystuje się ją do modyfikacji licznika pętli.
Przykład:

for(i = 1; i <= 10; i++)...

instrukcja  - instrukcja powtarzana w każdej iteracji pętli.
Przykład:

for(i = 1; i <= 10; i++) cout << i << endl;


 

Przykłady różnych pętli iteracyjnych

W poniższych przykładach zakładamy, iż wszystkie niezbędne zmienne zostały wcześniej odpowiednio zadeklarowane.

Pętla wypisuje kolejne liczby całkowite od 1 do 10:

for(i = 1; i <= 10; i++) cout << i << endl;

Pętla wypisuje liczby od 10 do 1 w kierunku odwrotnym:

for(i = 10; i >= 1; i--) cout << i << endl;

Pętla wypisuje kolejne liczby parzyste od 4 do 26:

for(i = 4; i <= 26; i += 2) cout << i << endl;

 

Zagnieżdżone pętle iteracyjne

Poniższy fragment programu wypisuje wiersz zbudowany z 20 znaków X:

for(i = 0; i < 20; i++) cout << "X";
cout << endl;

Jeśli powtórzymy ten fragment programu 20 razy, to otrzymamy kwadrat z literek X. Instrukcją powtarzaną w pętli może być druga pętla - otrzymamy wtedy układ zagnieżdżony:

for(j = 0; j < 20; j++)
{
    for(i = 0; i < 20; i++) cout << "X";
    cout << endl;
}

Pętla wewnętrzna jest sterowana zmienną i. Jej zadaniem jest wyświetlenie jednego wiersza 20 znaków X. Pętla ta jest powtarzana 20 razy przez pętlę zewnętrzną sterowaną zmienną j. W efekcie w oknie konsoli pojawia się 20 wierszy, każdy zbudowany z 20 literek X:

XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX

 

W pętlach zagnieżdżonych muszą być stosowane różne zmienne liczników pętli.

Jeśli ilość wykonań pętli wewnętrznej uzależnimy od numeru obiegu pętli zewnętrznej, to otrzymamy trójkąt:

for(j = 0; j < 20; j++)
{
    for(i = 0; i <= j; i++) cout << "X";
    cout << endl;
}

X
XX
XXX
XXXX
XXXXX
XXXXXX
XXXXXXX
XXXXXXXX
XXXXXXXXX
XXXXXXXXXX
XXXXXXXXXXX
XXXXXXXXXXXX
XXXXXXXXXXXXX
XXXXXXXXXXXXXX
XXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX

Zastanów się, jak zmienić podane pętle, aby uzyskać następujące wydruki w oknie konsoli:

XXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXX
XXXXXXXXXXXXXX
XXXXXXXXXXXXX
XXXXXXXXXXXX
XXXXXXXXXXX
XXXXXXXXXX
XXXXXXXXX
XXXXXXXX
XXXXXXX
XXXXXX
XXXXX
XXXX
XXX
XX
X

                   X
                  XX
                 XXX
                XXXX
               XXXXX
              XXXXXX
             XXXXXXX
            XXXXXXXX
           XXXXXXXXX
          XXXXXXXXXX
         XXXXXXXXXXX
        XXXXXXXXXXXX
       XXXXXXXXXXXXX
      XXXXXXXXXXXXXX
     XXXXXXXXXXXXXXX
    XXXXXXXXXXXXXXXX
   XXXXXXXXXXXXXXXXX
  XXXXXXXXXXXXXXXXXX
 XXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXX

XXXXXXXXXXXXXXXXXXXX
 XXXXXXXXXXXXXXXXXXX
  XXXXXXXXXXXXXXXXXX
   XXXXXXXXXXXXXXXXX
    XXXXXXXXXXXXXXXX
     XXXXXXXXXXXXXXX
      XXXXXXXXXXXXXX
       XXXXXXXXXXXXX
        XXXXXXXXXXXX
         XXXXXXXXXXX
          XXXXXXXXXX
           XXXXXXXXX
            XXXXXXXX
             XXXXXXX
              XXXXXX
               XXXXX
                XXXX
                 XXX
                  XX
                   X

                   XX
                  XXXX
                 XXXXXX
                XXXXXXXX
               XXXXXXXXXX
              XXXXXXXXXXXX
             XXXXXXXXXXXXXX
            XXXXXXXXXXXXXXXX
           XXXXXXXXXXXXXXXXXX
          XXXXXXXXXXXXXXXXXXXX
         XXXXXXXXXXXXXXXXXXXXXX
        XXXXXXXXXXXXXXXXXXXXXXXX
       XXXXXXXXXXXXXXXXXXXXXXXXXX
      XXXXXXXXXXXXXXXXXXXXXXXXXXXX
     XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
   XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
  XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

Utwórz pętle, które tworzą następujące wydruki:

XXXXXXXXXXXXXXXX
X              X
X              X
X              X
X              X
X              X
X              X
X              X
X              X
X              X
X              X
X              X
X              X
X              X
X              X
XXXXXXXXXXXXXXXX

XXXXXXXXXXXXXXXX
XX             X
X X            X
X  X           X
X   X          X
X    X         X
X     X        X
X      X       X
X       X      X
X        X     X
X         X    X
X          X   X
X           X  X
X            X X
X             XX
XXXXXXXXXXXXXXXX

XXXXXXXXXXXXXXXX
X             XX
X            X X
X           X  X
X          X   X
X         X    X
X        X     X
X       X      X
X      X       X
X     X        X
X    X         X
X   X          X
X  X           X
X X            X
XX             X
XXXXXXXXXXXXXXXX

XXXXXXXXXXXXXXXX
XX            XX
X X          X X
X  X        X  X
X   X      X   X
X    X    X    X
X     X  X     X
X      XX      X
X      XX      X
X     X  X     X
X    X    X    X
X   X      X   X
X  X        X  X
X X          X X
XX            XX
XXXXXXXXXXXXXXXX

XXXX    XXXX    XXXX    
XXXX    XXXX    XXXX
XXXX    XXXX    XXXX
XXXX    XXXX    XXXX
    XXXX    XXXX    XXXX
    XXXX    XXXX    XXXX
    XXXX    XXXX    XXXX
    XXXX    XXXX    XXXX
XXXX    XXXX    XXXX    
XXXX    XXXX    XXXX
XXXX    XXXX    XXXX
XXXX    XXXX    XXXX
    XXXX    XXXX    XXXX
    XXXX    XXXX    XXXX
    XXXX    XXXX    XXXX
    XXXX    XXXX    XXXX
 

Trójka pitagorejska, to trzy liczby naturalne a, b  i c, takie że:

 

a  < b  < c   i  a2 + b2 = c2

 

Słynnymi liczbami pitagorejskimi są na przykład liczby 3, 4 i 5. Zadanie sprowadza się do wygenerowania wszystkich trójek liczb a, b i c z przedziału od 1 do n, spełniających warunek

a  < b  < c:

a - generujemy od 1 do n - 2
b - generujemy od a + 1 do n - 1
c - generujemy od b + 1 do n

Zadanie generacji takich liczb spełnią trzy zagnieżdżone pętle iteracyjne, Następnie sprawdzamy w najbardziej wewnętrznej pętli, czy liczby te spełniają warunek trójki pitagorejskiej:

a2 + b2 = c2

Jeśli tak, to znalezioną trójkę wypisujemy.

 

// Trójki pitagorejskie


#include <iostream>

using namespace std;


int main()
{
    int a,b,c,n;

    cin >> n;  // odczytujemy zakres

    for(a = 1; a <= n - 2; a++)
        for(b = a + 1; b <= n - 1; b++)
            for(c = b + 1; c <= n; c++)
                if(a*a + b*b == c*c) cout << a << " " << b << " " << c << endl;
    return 0;
}

 

Zadania

Napisz następujące funkcje:
  1. polecenie1
    Obliczy sumę elementów ciągu arytmetycznego, składającego się ze 100 elementów, z których każdy kolejny jest większy od poprzedniego o 10.
    Pierwszy element podaje użytkownik.
  2. polecenie2
    Obliczy ilość cegieł w piramidzie o podstawie 10 x 10 cegieł.
  3. polecenie3
    Obliczy ilość cegieł w ścianie o podstawie X cegieł, wysokości Y rzędów cegieł, gdzie każdy kolejny stawiany rząd cegieł jest o Z cegieł krótszy od poprzedniego (niższego).
  4. polecenie4
    Oblicza wagę ściany z poprzedniego zadania, przy założeniu, że jedna cegła waży K kilogramów.
  5. polecenie5
    Wyświetli na ekranie ciąg arytmetyczny składający się z N elementów, gdzie pierwszy element ma wartość X, a różnica pomiędzy kolejnymi elementami ciągu wynosi Y.
  6. polecenie6
    Oblicza sumę dwóch liczb podanych przez użytkownika. Algorytm ma działać tak długo, aż suma podanych liczb będzie wynosiła 0.
  7. polecenie7
    Algorytm oblicza silnię (iloczyn kolejnych liczb) wprowadzonej przez użytkownika liczby.
  8. polecenie8
    Wypisuje na ekran ciąg n liczb, z których każda kolejna jest kwadratem poprzedniej liczby z ciągu.
    Wartość pierwszej liczby podaje użytkownik.
Projekt i wykonanie: Ryszard Rogacz© 1999−2024