-
Perhatikan potongan program berikut!
var we: longint; Z: array[1..15] of longint = (64, 19, 56, 67, 66, 82, 31, 20, 67, 10, 94, 100, 57, 14, 86); function f(x: longint; y: longint): longint; var a, b: longint; begin if (x = y) then f := Z[y] else begin a := f(x, (x+y) div 2); b := f((x+y) div 2+1, y); if (a < b) then f := a else f := b end end; begin we := f(3,11); writeln(we); end.
Apakah keluaran dari program tersebut?
Jika nilai x = y, maka fungsi akan bernilai Z[y]. Selain itu program akan membandingkan dari x sampai y, karena keduanya hanya akan berubah menjadi rata-rata dari nilai sebelumnya tanpa mengubah batas bawah dari x maupun y. Setelah itu fungsi akan mengembalikan nilai yang lebih kecil. Artinya jika program tersebut dijalankan maka akan mencari nilai terkecil dari index x awal sampai y awal. Dengan demikian f(3,11) = 10 karena 10 adalah bilangan terkecil dari jangkauan tersebut.
Pages: Page 1, Page 2, Page 3, Page 4, Page 5, Page 6, Page 7, Page 8, Page 9, Page 10, Page 11, Page 12, Page 13, Page 14, Page 15, Page 16, Page 17, Page 18, Page 19, Page 20, Page 21, Page 22, Page 23, Page 24, Page 25, Page 26, Page 27, Page 28, Page 29, Page 30, Page 31, Page 32, Page 33, Page 34, Page 35, Page 36, Page 37, Page 38, Page 39, Page 40, Page 41, Page 42, Page 43, Page 44, Page 45, Page 46, Page 47, Page 48, Page 49, Page 50