Uploaded by renysuyatin

04 Pengulangan

advertisement
PERULANGAN
PRODI S1 TEKNIK INFORMATIKA
RENY SULISTYOWATI
PENGULANGAN
Perulangan atau yang sering disebut dengan “looping”
digunakan untuk mengerjakan suatu perintah secara berulang-
ulang sesuai dengan yang diinginkan.
Struktur pengulangan terdiri atas dua bagian :
1. Kondisi pengulangan yaitu ekspresi Boolean yang harus
dipenuhi untuk melaksanakan pengulangan
2. Isi atau badan pengulangan yaitu satu atau lebih
pernyataan(aksi) yang akan diulang.
PENGULANGAN(2)
Perintah atau notasi dalam struktur pengulangan adalah :
1. Pernyataan For
2. Pernyataan while
3. Pernyataan do..while
4. Pernyataan continue dan break
5. Pernyataan go to.
STRUKTUR PERULANGAN
Struktur perulangan
 Inisialisasi
Aksi yang dilakukan sebelum pengulangan dilakukan pertama kali
 Terminasi
Aksi yang dilakukan setelah pengulangan selesai dilaksanakan.
<inisialisasi>
<terminasi>
Awal
dan akhir pengulangan
dinyatakan sebagai kata kunci yang
bergantung
pada
struktur
pengulangan yang dipakai.
Inisialisasi dan terminasi adalah
bagian yang opsional
FOR
Instruksi for digunakan untuk mengeksekusi atau menjalankan statement
/ perintah dengan jumlah pengulangan yang telah diketahui.
Bentuk umum :
for (inisialisasi;kondisi pengulangan;statement)
{
statement
}
Keterangan :
 Inisialisasi merupakan pemberiannilai awal.
 Kondisi Pengulangan : memegang kontrol terhadap pengulangan, karena bagian
ini yang akan menentukansuatu perulangan diteruskan atau dihentikan.
 Statement: mengatur kenaikan ataupenurunan nilai pencacah. Bila pernyataan
didalam for lebih dari satu maka pernyataan-pernyataan tersebut harus
diletakan didalam tanda kurung
Contoh 1
#include<iostream>
using namespace std;
main(){
int a;
for(a=0;a<=10;a++) {
cout<<a<<“ ";
}
}
PROGRAM Cetak0sampai10
{Mencetak 0,2,……., a}
DEKLARASI
a : integer
ALGORITMA
for a  0 to a do {ulangi sebanyak a kali}
write (a)
endfor
Contoh 2
#include<iostream>
using namespace std;
main(){
for(int a=20;a>=1;a-=2){
cout<<a<<endl;
}
}
PROGRAM Cetak20sampai2
{Mencetak 20,18,……., a}
DEKLARASI
a : integer
ALGORITMA
for a  20 to a do
a=a-2
write (a)
endfor
Contoh 3
Selain berupa angka, pencacah perulangan juga dapat berupa karakter.
#include<iostream>
using namespace std;
main(){
char huruf;
for(huruf='Z'; huruf >='A';huruf--){
cout<<"Huruf abjad ="<<huruf<<"\n";
}
}
NESTED FOR
Perulangan bertumpuk secara sederhana dapat diartikan : terdapat satu
atau lebih loop di dalam sebuah loop. Banyaknya tingkatan perulangan,
tergantung dari kebutuhan. Biasanya, nested loops digunakan untuk
membuat aplikasi matematika yang menggunakan baris dan kolom. Loop
luar, biasanya digunakan untuk mendefinisikan baris. Sedangkan loop
dalam, digunakan untuk mendefinisikan kolom
CONTOH
for(int baris=1;baris<=4;baris++){
for(int kolom=1;kolom<=5;kolom++){
cout<<kolom<<"";
}
cout<<endl;
}
Penjelasan Program
baris=1;
kolom = 1; cetak 1
kolom = 2; cetak 2
kolom = 3; cetak 3
kolom = 4; cetak 4
kolom = 5 ; cetak 5
ganti baris !
….
….
baris =4;
kolom = 1; cetak 1
kolom = 2; cetak 2
kolom = 3; cetak 3
kolom = 4; cetak 4
kolom = 5 ; cetak 5
ganti baris
SELESAI
LATIHAN SOAL
#include<iostream>
using namespace std;
main(){
int bil;
cout<<"Inputkan Jumlah Bintang = ";cin>>bil;
for(int i=1;i<=bil;i++){
for(int j=1;j<=i;j++){
cout<<"*";}
cout<<endl;}
}
WHILE
Bentuk umum :
while condition {
statement
}
Keterangan :
 Struktur while akan memeriksa kondisi pengulangan diawal blok
struktur.
 statement akan dilaksanakan berulangkali selama kondisi bernilai true,
jika false badan pengulangan tidak akan dimasuki yang berarti
pengulangan selesai.
 kondisi diakhir pengulangan disebut loop invariant yaitu variable
kondisi yang nilainya sudah tidak berubah lagi.
WHILE
#include<iostream>
#include<conio.h>
using namespace std;
main(){
cout<<"Program Konversi angka ke huruf"<<endl;
cout<<endl;
cout<<"Masukkan Angka : ";
int angka,i;
char huruf; cin>>angka; cout<<endl;
i=1;
huruf='A';
while(i<=angka){
cout<<i<<"--> "<<huruf<<endl;
i++;
huruf++;}
getch();
}
DO WHILE
Karakteristik do ... while() adalah:
1. Perulangan akan dilakukan minimal1 x terlebih dahulu, kemudian baru
dilakukan pengecekan terhadap kondisi, jika kondisi benar maka
perulangan masih akan tetap dilakukan.
2. Perulangan dengan do...while() akan dilakukan sampai kondisi false
Bentuk umum
do {
statement
}while
PERBEDAAN WHILE DAN DO WHILE
 DO WHILE statement perulangannya dilakukan terlebih dahulu baru
kemudian di cek kondisinya.
 Sedangkan WHILE kondisi dicek dulu baru kemudia statement
perulangannya dijalankan.
Akibat dari hal ini adalah dalam DO WHILE minimal terdapat 1x
perulangan. Sedangkan WHILE dimungkinkan perulangan tidak pernah
terjadi yaitu ketika kondisinya langsung bernilai FALSE.
CONTOH
#include<iostream>
#include<conio.h>
Using namespace std;
main() {
int angka=0;
do
{
angka++;
if (angka % 2 ==0)
cout<<angka<<" ";
}
while (angka<=30);
getch();
}
CONTINUE DAN BREAK
Pernyataan break akan selalu terlihat digunakan bila menggunakan
pernyataan switch. Pernyataan ini juga digunakan dalam loop. Bila
pernyataan ini dieksekusi, maka akan mengakhiri loop dan akan
menghentikan itrasi pada saat tersebut.
Pernyataan continue digunakan untuk pergi ke bagian awal dari blok loop
untuk memulai iterasi berikutnya. Dengan kata lain, perintah continue
akan melewati satu iterasi yang sesuai dengan syarat tertentu, dan
melanjutkan ke iterasi berikutnya.
CONTOH
#include<iostream>
using namespace std;
int main() {
int i;
for (i=0;i<10;i++){
if(i==4) continue;
cout<<"Bilangan"<<i<<endl;
if(i==6) break;
}
}
GO TO
Pernyataan goto, diperlukan untuk melakukan suatu lompatan ke suatu
pernyataan berlabel yang ditandai dengan tanda “ : “
Contoh :
#include<iostream>
using namespace std;
main() {
cout<<"Tes go to"<<endl;
goto selesai;
cout<<"Dilewatkan"<<endl;
selesai:
cout<<"selesai......"<<endl;
}
LATIHAN
1. Buatlah program untuk menampilkan bilangan prima sampai deret ken! Jika inputan = 10, maka hasil 2 3 5 7
2. Buatlah program untuk menampilkan
Untuk n=5
xoxox
xoxo
xox
xo
x
3. Buatlah deret bilangan fibonacci
Bilangan fibonacci adalah bilangan seperti: 1 1 2 3 5 8 13 ... dst
Jadi jika inputan n = 7, maka hasil adalah 13
TUGAS 1
Buatlah simulasi menu program dengan tampilan di bawah ini
menggunakan Do … WHILE.
MENU PILIHAN
1. Baca Data
2. Ubah Data
3. Hapus Data
4. Exit
Pilihan Anda (1/2/3/4) ? ...
Keterangan :
Apabila dipilih menu no 1, maka akan tampil teks “Anda memilih menu 1”.
Demikian pula untuk menu 2 dan 3. Kemudian setelah itu muncul teks
“Tekan ENTER untuk kembali ke menu utama”. Artinya begitu kita tekan
ENTER menu
TUGAS 2
Tuliskan Algoritma dan program untuk melakukan penjumlahan seperti
berikut :
1 1 1 1
1 − + − + − ⋯……..
2 3 4 5
Sampai suku ke-n (n yang diinput)
TUGAS 3
Buatlah program pengulangan for bersarang yang menampilkan tampilan
seperti berikut :
Download