Upload presentasi
Presentasi sedang didownload. Silahkan tunggu
1
Algoritme dan Pemrograman
Kuliah #6 1. Kontrol program (lanjutan) Do … While For Nested loop 2. Fungsi ILKOM IPB
2
Loop control structures: DO … WHILE
Implementasi dari pernyataan: Lakukan sesuatu. Kemudian ulangi sesuatu itu selama kondisi bernilai true Berarti memproses pernyataan di dalamnya terlebih dahulu, baru kemudian memeriksa kondisi yang ada. Pernyataan akan diproses minimal SATU kali. Format: do { pernyataan; } while (kondisi); DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
3
Loop control structures: DO … WHILE
#include <stdio.h> main() { int i, n=5; i=0; do { printf("%d ", i); i++; } while (i<n); return 0; } Output program tersebut adalah: DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
4
Loop control structures: DO … WHILE
statement while (kondisi) kondisi ? TRUE Pernyataan (statements) di dalam struktur DO … WHILE akan diproses minimum SATU kali. Mengapa? FALSE DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
5
Contoh: Program menulis bilangan
#include <stdio.h> main() { int n; scanf("%d", &n); do { printf("%d", n%10); n /= 10; } while (n); return 0; } Jika diberikan input 120, apa output program tsb? DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
6
Loop control structures: FOR
Pernyataan for umumnya digunakan untuk memproses pernyataan secara berulang- ulang, dimana kita sebelumnya sudah mengetahui berapa kali pernyataan tersebut akan diulang. Contoh: Menuliskan bilangan bulat 1 sampai dengan 5 Membaca n bilangan bulat. DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
7
Loop control structures: FOR
Bentuk umum for (expr1; expr2; expr3) { s1; s2; ... } Proses yang dilakukan mengikuti alur berikut: expr1 dieksekusi hanya satu kali sebelum mulai looping. expr2 merupakan ekspresi Boolean. Jika tidak dituliskan, diasumsikan bernilai true. Jika expr2 bernilai false, maka proses looping dihentikan. Jika expr2 bernilai true, maka s1, s2, ... dieksekusi. Setelah eksekusi s1, s2, ..., maka expr3 dieksekusi. expr1, expr2, dan expr3 bersifat optional (dapat dituliskan, juga dapat tidak dituliskan). DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
8
Loop control structures: FOR
expr1 FOR (expr1 ; expr2 ; expr3) S; FALSE expr2 ? TRUE S expr3 DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
9
Pernyataan FOR: Contoh #1
#include <stdio.h> main(){ int i,n = 5; for (i=0; i<n; i++) { printf("%d", i); } return 0; Apa output program tersebut ? (ikuti diagram FOR pada slide sebelumnya) DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
10
Pernyataan FOR – loop backward: Contoh #2
#include <stdio.h> main(){ int i=5; for ( ; i; i--) { printf("%d", i); } return 0; Apa output program tersebut ? DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
11
Pernyataan FOR – loop backward: Contoh #3
#include <stdio.h> main(){ int i, n=5, sum=0; for (i=1 ; i<=n; sum+=i++); printf("%d\n", sum); return 0; } Apa output program tersebut ? Apa yang dilakukannya? DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
12
Pernyataan FOR: Contoh #4
#include <stdio.h> main() { int i, n, bil, sum=0; scanf("%d", &n); for (i=1; i<=n; i++) { scanf("%d", &bil); sum+=bil; } printf("%d\n", sum); return 0; Apa output program jika diberi input ? Apa yang dilakukan program tersebut? DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
13
Loop control structures: Nested FOR
Pernyataan for yang bersarang, artinya terdapat pernyataan for lainnya di dalam pernyataan for. Contoh, apa output potongan program berikut? int i, j; for (i=1; i<=2; i++) { for (j=1; j<=3; j++) { printf("*"); } printf("\n"); DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR ILKOM IPB
14
Nested FOR: Menulis bilangan bentuk matrik
Misalkan ingin menuliskan bilangan 1, 2, … dalam bentuk matrik ukuran 3x4. Setiap baris hanya diakhiri oleh newline. Digunakan nested for: #include <stdio.h> main() { int i, j, c=1; for (i=1; i<=3; i++) for (j=1; j<=4; j++) { printf("%d", c++); if (j!=4) printf(" "); else printf("\n"); } return 0; DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
15
Nested FOR: Menggunakan variabel sebelumnya
Perhatikan contoh berikut, dimana di dalam for untuk variabel j menggunakan variabel i. Apa outputnya? Apa yang dilakukan? int i, j, sum; for (i=1; i<=3; i++) { sum=0; for (j=1; j<=i; j++) sum+=j; printf("%d %d\n", i, sum); } DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
16
Nested FOR: Menggunakan variabel sebelumnya
Apa output potongan program berikut? int i, j, n=4; for (i=1; i<=n; i++) { for (j=i; j<=n; j++) printf("*"); printf("\n"); } DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
17
Latihan #1 Berapa kali teks IPB dicetak oleh program berikut?
#include <stdio.h> main() { int i; for (i=1; i<=20; i++) { if (i=5) printf ("IPB\n"); } return 0; Apa yang dapat disimpulkan dari kasus ini ? DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
18
Latihan #2 Buat program untuk membaca sebuah bilangan bulat n, dan menampilkan output seperti dalam contoh. Setiap baris output hanya diakhiri dengan newline. Contoh input: 5 Contoh output: * ** *** **** ***** DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
19
Fungsi Contoh fungsi y=f(x)=x2+5.
Nilai yang mungkin untuk variabel x disebut daerah fungsi (df), dan untuk variabel y atau f(x) disebut wilayah fungsi (wf). Nilai yang diberikan pada df akan menentukan nilai yang dihasilkan pada wf. Pada contoh tersebut: f disebut nama fungsi x disebut argumen fungsi x2+5 disebut tubuh fungsi (function body) Tipe data dari y disebut return type. DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
20
Fungsi y = f (x) = x2 + 5 m = jumlah ( a, b ) = a + b return value
arguments function body function name m = jumlah ( a, b ) = a + b DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
21
Bentuk umum fungsi dalam C
return-type function-name parameter-list { local definitions; statements; return value; } Return type tipe dari hasil fungsi. Function name nama fungsi (berupa identifier). Parameter list daftar variabel, dituliskan di dalam tanda kurung (), dipisahkan oleh tanda koma (,). DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
22
Contoh : Fungsi menjumlah dua bilangan
#include <stdio.h> int jumlah(int x, int y) { // Fungsi jumlah int t; t = x+y; return t; } main() { // Fungsi utama int a, b, c; scanf("%d %d", &a, &b); c=jumlah(a,b); // Memanggil fungsi printf( "%d\n", c); return 0; DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
23
Function prototype Prototipe fungsi terdiri dari tiga elemen:
return type, function name, dan parameter list. Setiap fungsi harus dituliskan sebelum fungsi main, berupa fungsi lengkap atau hanya prototipe. Jika berupa prototipe, maka fungsi lengkapnya dituliskan di bawah fungsi main. DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
24
Function prototype #include <stdio.h> int jumlah(int, int); // Function prototype main() { int a, b, c; scanf("%d %d", &a, &b); c=jumlah(a,b); printf( "%d\n", c); return 0; } int jumlah(int x, int y) { int t; t = x+y; return t; DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
25
Variabel lokal Variabel yang didefinisikan dan dideklarasikan di dalam suatu fungsi hanya berlaku di dalam fungsi tersebut. Disebut sebagai variabel lokal. Hal ini berarti bahwa variabel yang dibuat di dalam satu fungsi tidak ada hubungannya dengan variabel di fungsi lainnya walaupun menggunakan nama yang sama. DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
26
Variabel lokal : Apa output program berikut?
#include <stdio.h> int test(int a, int b) { int c; a = 2*b; b = a - b; c = a + b; return c; } main() { int a=5, b=10, c=15, d; d = test(a,b); printf("%d %d %d %d\n", a, b, c, d); return 0; DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
27
Void Jika fungsi tidak mengembalikan nilai apapun, maka return-type adalah VOID. Contoh (apa yang dilakukan?): void pola(int n) { int i, j, n=4; for (i=1; i<=n; i++) { for (j=i; j<=n; j++) printf("*"); printf("\n"); } DEPARTEMEN ILMU KOMPUTER INSTITUT PERTANIAN BOGOR
Presentasi serupa
© 2024 SlidePlayer.info Inc.
All rights reserved.