Tutorial Belajar C: Cara Membuat Perulangan Bersarang (Nested Loop)

Salah satu konsep programming yang cukup banyak dipakai (dan juga sedikit rumit), adalah perulangan bersarang atau nested loop. Dalam tutorial kali ini kita akan lihat praktek pembuatan perulangan bersarang dalam bahasa C.


Pengertian Perulangan Bersarang (Nested Loop)

Perulangan bersarang adalah sebutan untuk perulangan di dalam perulangan. Konsep seperti ini sering dipakai untuk memecahkan masalah programming yang cukup kompleks. Semua jenis perulangan bisa dibuat dalam bentuk perulangan bersarang, termasuk perulangan FOR, WHILE dan DO WHILE. Dalam bahasa inggris, perulangan bersarang ini dikenal dengan sebutan nested loop.

Berikut contoh format dasar perulangan bersarang dalam bahasa C:

for (start1; condition1; increment1) 
{
  // kode program
  for (start2; condition2; increment2) 
  {
     // kode program
  }
}

Di dalam perulangan bersarang terdapat istilah outer loop dan inner loop. Sesuai dengan namanya, outer loop adalah sebutan untuk perulangan luar, sedangkan inner loop sebutan untuk perulangan dalam.

Pada contoh di atas, outer loop adalah perulangan di baris 1, sedangkan inner loop adalah perulangan di baris 4. Kode program di dalam outer loop akan dijalankan sejumlah kondisi perulangan di outer saja. Sedangkan kode program yang ada di dalam perulangan inner loop akan dijalankan sebanyak perulangan outer * inner.

Tidak ada batasan seberapa banyak "kedalaman" dari sebuah perulangan bersarang. Kita bisa saja membuat perulangan di dalam perulangan di dalam perulangan, dst. Tentu saja semakin banyak perulangan yang "bersarang", kode programnya juga akan makin kompleks.

Dalam membuat perulangan berasarang kita juga harus sangat teliti dalam penggunaan tanda kurung kurawal "{ }" untuk menandakan awal dan akhir sebuah blok kode program. Tidak jarang hasilnya jadi berantakan karena salah menulis posisi penutup kurung kurawal.


Contoh Kode Program Perulangan Bersarang (Nested Loop)

Mari kita masuk ke contoh kode program dari perulangan bersarang dalam bahasa C. Namun sebelum itu, kita berangkat dari perulangan "normal" terlebih dahulu.

Latihan pertama, bisakah anda merancang kode program untuk membuat daftar perkalian 3 dari 1 sampai 10? Hasil akhir yang saya inginkan adalah seperti ini:

3 * 1 = 3
3 * 2 = 6
3 * 3 = 9
3 * 4 = 12
3 * 5 = 15
3 * 6 = 18
3 * 7 = 21
3 * 8 = 24
3 * 9 = 27
3 * 10 = 30

Tentu saja baris di atas bisa dihasilkan dengan membuat perintah printf sebanyak 10 kali, namun hal itu tidak efisien. Hasil di atas harus dibuat menggunakan perulangan FOR.

Baik, berikut kode program yang saya gunakan:

#include <stdio.h>

int main(void)
{
  for (int i = 1; i <= 10; i++) {
    printf("3 * %i = %i\n",i,3*i);
  }
  return 0;
}

Disini saya menggunakan sebuah perulangan FOR. Perulangan mulai dari variabel counter i = 1 sampai i <= 10. Sepanjang perulangan, tampilkan hasil dari printf("3 * %i = %i\n",i,3*i).

Jika anda sudah memahami konsep dasar perulangan FOR, maka kode program ini seharusnya bisa dipahami dengan mudah.

Berikutnya, bagaimana dengan membuat kode program untuk menghasilkan daftar perkalian yang sama seperti di atas, tapi kali ini bukan hanya perulangan 3 saja, tapi dari 1 – 10. Maksudnya, saya ingin membuat kode program yang menghasilkan 100 baris daftar perkalian, mulai dari:

1 * 1 = 1
1 * 2 = 2
1 * 3 = 3
....
....

Sampai dengan:

....
....
10 * 8 = 80
10 * 9 = 90
10 * 10 = 100

Ada beberapa cara untuk membuat daftar perkalian seperti ini, misalnya bisa dengan membuat 10 kali perulangan FOR (1 perulangan untuk setiap angka). Namun cara paling efisien adalah menggunakan perulangan bersarang.

Berikut contoh kode program yang bisa dipakai:

#include <stdio.h>

int main(void)
{
  for (int i = 1; i <= 10; i++) {
    for (int j = 1; j <= 10; j++) {
      printf("%i * %i = %i\n",i,j,j*i);
    }
    printf("\n");
  }
  return 0;
}

Contoh kode program perulangan bersarang bahasa pemrograman C

Untuk membuat perulangan bersarang, kita butuh 2 buah variabel counter, yakni 1 untuk outer loop, dan 1 untuk inner loop. Dalam contoh ini saya menggunakan variabel i dan j.

Perulangan i (outer loop) akan diulang sebanyak 10 kali, yakni dari i = 1 sampai i <= 10. Di dalam setiap perulangan i ini, akan di proses perulangan j (inner loop). Perulangan j jukan akan di proses sebanyak 10 kali. Dengan demikian, perintah printf di baris 7 akan dijalankan sebanyak 100 kali, yakni total dari i * j.

Inilah salah satu contoh penerapan perulangan bersarang dalam bahasa C.

Sebagai tantangan terakhir, bisakah anda meng-konversi nested loop diatas menjadi perulangan WHILE? Silahkan dicoba sebentar.

Baik, berikut kode program untuk hasil yang sama namun kali ini dengan perulangan WHILE:

#include <stdio.h>

int main(void)
{
  int i = 1;
  int j;
  while (i <= 10) {
    j = 1;
    while (j <= 10) {
      printf("%i * %i = %i\n",i,j,j*i);
      j++;
    }
    printf("\n");
    i++;
  }
}

Membuat nested loop dengan perulangan WHILE memang butuh tantangan tersendiri, karena kita harus memikirkan kapan sebuah variabel harus di deklarasikan. Sebagai contoh, perintah j = 1 harus berada di dalam perulangan i, namun sebelum perulangan j.


Dalam tutorial belajar bahasa C kali ini kita telah membahas konsep dari perulangan bersarang atau nested loop. Meskipun cukup rumit, konsep perulangan ini sangat penting sepanjang karir kita sebagai programmer. Kuncinya ada di latihan kode program. Semakin banyak berlatih memecahkan masalah, anda akan semakin terampil dalam merancang kode program.

22 Comments

  1. unknown
    07 Nov 19
    • Andre
      07 Nov 19
    • redkoala
      10 Jan 23
      • Andre
        10 Jan 23
  2. AdyaJudha
    06 Apr 20
    • Andre
      06 Apr 20
      • AdyaJudha
        06 Apr 20
      • AdyaJudha
        06 Apr 20
        • Andre
          07 Apr 20
  3. newbie
    29 Apr 20
  4. Khamad Ali
    26 Jul 20
  5. dzaazz
    01 Oct 20
  6. GIlang
    02 Dec 20
  7. Lian
    29 Dec 20
  8. Jkh
    29 Dec 20
    • Andre
      30 Dec 20
  9. valentino francisco
    26 Mar 22
  10. ceqmek
    19 Oct 22
  11. fitri
    03 Nov 22
  12. Arie
    24 Jan 23

Add Comment

Leave a Reply to valentino francisco Cancel reply