Ketika merancang suatu program, urut-urutan atau algoritma yang digunakan haruslah berupa instruksi yang jelas, tidak ambigu atau menimbulkan persepsi yang berbeda-beda. Memberikan perintah “cari”, “tampilkan”, atau “minta masukkan” merupakan perintah yang ambigu karena tidak memiliki skopa (ruang lingkup) yang jelas. Apa yang hendak dicari? Apa yang hendak ditampilkan? Masukkan seperti apa yang diinginkan? Apakah masukan berupa angka? Berupa teks? Berupa tanggal? Berupa jam? Instruksi “cari” dapat diperjelas (agar tidak menjadi ambigu) menjadi: “cari huruf A pada teks yang dimasukkan oleh pengguna” atau “tampilkan hasil pencarian yang diperoleh pada langkah sebelumnya”. Jika instruksi pada algoritma tidak jelas, maka akan muncul kesulitan saat diterapkan ke dalam bahasa pemrograman.

Ilustrasi Algoritma

Berikut adalah 2 contoh algoritma dalam kasus sehari-hari yang ambigu.

Algoritma a: Mengganti harddisk pada PC:

  1. Buka casing PC
  2. Cabut kabel
  3. Pasang harddisk
  4. Nyalakan komputer
  5. Jika harddisk belum terbaca, ulang kembali
  6. Tutup casing

Algoritma b: Algoritma untuk memasak nasi:

  1. Masukkan beras
  2. Bilas beras beberapa kali
  3. Tambahkan air pada beras
  4. Nyalakan rice cooker
  5. Tunggu

Pada kedua algoritma tersebut banyak perintah yang ambigu (menimbulkan persepsi yang berbeda-beda antar orang yang membaca atau menjalankan algoritma tersebut). Sebagai contoh, pada algoritma a, langkah 2 diminta untuk mencabut kabel. Kabel yang mana yang dicabut? Pada langkah 5 tertulis, “jika harddisk belum terbaca, ulang kembali”. Ulang dari mana? Dari langkah 1? Atau dari langkah 2? Perbaikan langkah yang bisa dilakukan agar tidak ambigu misalnya, “Jika harddisk belum terbaca, ulang kembali ke langkah 3.”

Pada algoritma b, langkah 2 “Bilas beras beberapa kali” merupakan langkah yang ambigu. Kata “beberapa kali” dapat menimbulkan persepsi yang berbeda-beda, apakah 3 kali? Atau 10 kali? Perbaikan yang bisa dilakukan agar tidak ambigu, misalnya “Bilas beras 3 kali”