Algoritma dan pemograman menggunakan bahasa Pascal (PART 1

)
Posted on November 12, 2009 by Andri Indrawan Pendahuluan Sebelum beranjak kepada pembahasan tema apa itu Algoritma, sebaiknya kita mengenok terlebih dahulu kepada bentuk-bentuk permsalahan dan tata cara, aturan main dan mekanisme penyelesaiannya yang senantiasa terjadi dalam kehidupan kita sehari-hari. Dalam kehidupan kita sehari-hari, beragam permasalahan senantiasa muncul ditengah-tengah hiruk pikuk aktivitas kita. Ambil contoh sederhana dalam menyelesaikan permasalahan mendasar kehidupan manusia, yaitu menghilangkan rasa lapar dengan makan. Kita senantiasa mengetahui bahwasyahnya lapar merupakan suatu indikasi permasalah diri yang mesti kita cari bagaimana menyelesaikannya, kita tahu bahwa lapar merupakan salah satu bentuk dari kekurangan diri maka apa dan bagaimana bentuk dalam menyempurnakannya. Kita sekarang tahu bahwa lapar adalah permasalahannya dan makan merupakan solusinya. Untuk mencapai solusi kita mesti tahu bahwa solusi yang hendak dikejar merupakan suatu bentuk penyelesaian yang dapat memberikan efek terhadap hilangnya suatu permasalahan dan menimbulkan suatu hal baru dari kebalikan dari rasa lapar itu sendiri yaitu rasa kenyang. Jika saja makan sebagai suatu solusi tidak dapat memberikan efek menghilangkan rasa lapar dan menimbulkan rasa kenyang, maka makan yang kita anggap sebagai solusi itu merupakan suatu kekeliruan, atau jika makan memang merupakan solusi yang sebenarnya berarti ada suatu mekanisme yang salah dalam mencapai dan melakukan makan tersebut, misal makan ditunjukan untuk aktivitas memakan makanan yang dapat memberikan nutirisi pada tubuh bukan makanan asal yang dimana keadaan tubuh tetap kekurangan nutrisi sehingga saraf-saraf yang ada pada tubuh tetap memberikan sinyal kepada otak bahwa tubuh kekurangan nutrisi dan tetap menimbulkan rasa lapar. Atau kita keliru dalam melakukan langkah pencapaian dalam menemukan makanan sehingga yang kita temukan hanyalah minuman, maka aktivitas makan tetap tidak dapat kita laksanakan. Untuk kasus yang lain dalam menujukan bahwa bukan hanya mekanisme dalam pencapaian dan menjalankan solusi yang ada dapat menjadi kekeliruan tetapi juga dari penujukan solusi yang diharapkan. Misal kita tahu bahwa kita sedang lapar maka merokok adalah solusinya, contoh lain ketika seseorang mengetahui dirinya tertolak dalam melamar suatu pekerjaan maka meminum minuman keras lah solusinya, atau kita tahu bahwa dilingkungan kita terjadi suatu praktek ketidak adilan dan kita tahu bahwa ketidak adilan merupakan suatu kekeliruan yang berefek tidak baik maka bersabar dan beribadah sajalah solusinya?. Nah Algoritma dalam dunia pemograman sebenarnya dapat dimengerti keberadaannya dari gambaran peristiwa diatas, dimana Algoritma ini hadir sebagai suatu bentuk jiwa dan kerangka dari struktur program guna memenuhi kebutuhannya mulai dari penujukan dan pencapaianpencapaian hasil yang diharapkan dari keberadaan progam itu sendiri.

tata cara. Secara umum. dikatakan bahwa Algoritma adalah urutan logis pengambilan keputusan untuk pemecahan masalah. Adapun pihak-pihak yang dapat dikatakan pemroses secara umum dapat berupa manusia. Belajar memogram berarti belajar bagaimana membuat atau menentukan suatu strategi. kata Algorithm diserap menjadi Algoritma. robot. dan . Dalam bahasa Indonesia. Adapun notasi yang dimaksud merupakan suatu bahasa pemograman tertentu. maka kita dapat mendefinisikan Algoritma sebagai metoda atau urutan dari langkah-langkah yang logis dalam penyelesaian suatu masalah dan tersusun secara sistematis. Secara istilah atau termonologis. Secara komprehensif belajar memogram identik dengan mendesain program. kata Algorism didapat dari penulis buku Arab terkenal yaitu Abu Ja’far Muhammad ibnu Musa al-Kuwarizmi. karena pemroses mesti melakukan urutan langkah secara pasti dan benar terhadap Algortima. dan sistematika pemecahan permasalahan.Pengertian Algoritma dan Pemograman Secara bahasa atau etimologis. dari sudut pandang pemroses setidaknya ada beberapa hal yang mesti diperhatikan yaitu pemroses mesti memahami setiap langkah dalam Algoritma dan pemroses harus dapat mengerjakan operasi yang bersesuaian dengan langkah tersebut. mesin. bahwa ada perbedaan secara mendasar antara apa itu belajar memogram dengan belajar bahasa pemograman. Karena penggunaan kata Algorism sering di salah artikan dalam dunia matematik dengan penggunaan kata Arithmetic. metodologi. Sedangkan dalam melakukan pemograman senantiasa melibatkan data maka dapat dikatakan secara simbolik program = Algoritma + struktur data. kemampuan analisis dan sintesis. Algoritma harus dibuat secara benar dan dituangkan ke dalam bahasa yang dapat dimengerti oleh pemroses. Dalam belajar memogram diperlukan adanya pemahaman terhadap persoalan yang ditunjuk. maka –sm berubah menjadi –thm yaitu menjadi Algorithm. Perlu diperhatikan. komputer dan alat-alat mesin lainnya. Dengan uraian dari pengertian diatas. Dalam buku yang berjudul Kitab al jabr w’almuqabala atau “Buku Pemugaran dan Pengurangan” (The book of restoration and reduction). Selain itu agar penyelesaian permasalahan yang sesuai dapat terjadi. Adapun belajar bahasa pemograman. ialah belajar untuk dapat menggunakan suatu bahasa pemograman tertentu diantara lain mempelajari aturan. Keberadaan Algoritma didalam dunia informatika atau ilmu komputer dinilai sangatlah penting. Sedangkan kata Algorist dikenakan bagi seseorang yang ahli dalam menggunakan perhitungan dengan angka Arab. yang berarti proses menghitung dengan angka Arab. menurut buku Kamus Besar Bahasa Indonesia terbitan Balai Pustaka 1988. Dengan kata lain program merupakan implementasi dari Algoritma. Banyak cabang dari ilmu komputer yang diacu ke dalam termonolgi Algortima ini. Algoritma yang dituangkan ke dalam bahasa tertentu (notasi) yang dapat dimengerti oleh pemroses dapat dikatakan sebagai program. sintaksis. Menurut sejarah perjalanan matematik. jika kita cari asal-usul kata dari Algoritma yaitu Algorism. pemroses (Processor) merupakan pihak yang melakukan suatu proses dengan melaksanakan atau mengeksekusi Algoritma yang terdefinisikan dan terjabarkan didalam proses tersebut.

Mendefinisikan masalah. 5. Menulis dokumentasi. Menguji program. langkah-langkah penyelesaian dan keluaran (output). dari pendefinisian masalah diatas maka menentukan bagaimana pemecahannya dengan tetap mempertimbangkan ketepatan dalam pencapaian sasaran dan penggunaan waktu yang dibutuhkan. Setiap langkah yang telah ditentukan harus terdefinisi dengan jelas dan tepat sehingga tidak mempunyai arti ganda. Langkah-langkah dalam pemograman setidaknya meliputi: 1. Belajar bahasa pemograman lebih ditekankan ke coding. Algoritma harus efektif dan sedeherna sehingga dapat dikerjakan dengan waktu yang rasional. Menentukan solusi. 6. Algoritma harus berhenti setelah mengerjakan sejumlah langkah-langkah yang telah ditentukan. tahapan ini kita masih dalam mencari permasalahan yang hendak dipecahkan dengan mempertimbangkan sumber daya (resource) yang ada dan hasil yang kita inginkan. Memilih Algoritma. Selain memberikan komentar dalam kode program.pemanfaatan intruksi-intruksi spesifik (key word) bawaan. Algoritma dapat mempunyai nol atau lebih keluaran. 4. Algoritma dalam urutan aksinya harus menekankan kepada setiap kejadian yang terjadi pada selang waktu tertentu (terbatas) yaitu dimulai saat T0 (Initial State/ Keadaan Awal) dan berakhir pada T1 (Final State/ Keadaan Akhir) serta menghasilkan efek netto yang terdefinisi dengan baik dan sesuai dengan apa yang direncanakan sejak awal. 5. dari Algoritma yang ada maka kita tinggal menuangkannya kedalam bahasa pemograman tertentu yang kita gunakan. Menulis program. ketika tahapan ini kita harus dapat membuat dan menentukan mana Algoritma yang paling sesuai yang dapat kita terapkan dalam pemecahan permasalahan yang ada. 2. fungsi atau prosedure program yang kita buat ataupun tatacara penggunaan dari masing- . 3. 3. Penambahan komentar pada setiap blok program atau sintaks program tertentu diperlukan untuk kemudahan dalam perbaikan dan pengembangan program. dokumentasi juga ditunjukan untuk pembendaharan dan penjelasan dari masing-masing keyword. tahap ini diperlukan untuk mengetahui kesesuaian dan ketepatan dengan tujuan awal. 4. Algoritma dapat mempunyai nol atau lebih masukan. Seperti yang dapat kita simpulkan bahwa pemograman merupakan aktivitas dalam menulis Algoritma yang dituangkan ke dalam notasi / bahasa pemograman tertentu yang dapat dimengerti oleh komputer. icon. Tahap ini memberikan beberapa kasus permasalahan yang diuji cobakan terhadap jalannya program dengan melihat aspek-aspek dari masukan (input). 2. Aturan Pembuatan Algoritma Menurut Donald E Knuth[1] Algoritma harus memiliki ciri-ciri sebagai berikut: 1. tahapan ini dapat dilakukan sejak awal bersamaan dengan aktivitas penulisan program.

Flowcharts 2. Deklarasi (Kamus) 3. Secara bahasa. yaitu: 1. Pseudecode Dari ketiga model diatas. Merawat program. . backup data. khususnya di Indonesia. PASCAL. Judul (Header) Judul merupakan bagian kepala yang berisi nama algoritma dan penjelasan spesifik mengenai algoritma tersebut seperti cara kerja. Deskripsi Pada setiap bagian tersebut dapat kita berikan dokumentasi berupa komentar. Pseudecode Pseudecode adalah pemodelan algoritma dengan menggunakan kode yang mirip dengan kode pemograman yang sebenarnya. model terakhir yaitu pseudecode lah yang amat banyak digunakan dan populer dikalangan para pemrogramam. Judul (Header) 2. 7. dan 3. Untuk memberikan komentar kita gunakan kurung kurawa contoh {komentar}. Jika pemogram melakukannya dengan cara mencari kemungkinan BUG yang ada dan memperbaikinya maka end user melakukannya dengan cara menggunakan program sesuai dengan petunjuk dan batasannya ataupun restore program (restore. tahapan ini merupakan runtinitas yang dilakukan oleh pemogram atau user end. C. Ada beberapa bagian algoritma di dalam Pseudecode. Nassi Scheniderman (Ns Diagram). seperti BASIC. Pemodelan Algoritma Pemodelan Algoritma merupakan aktivitas dalam mengilustrasikan jalannya suatu alur Algoritma dalam program dengan menggunakan simbol dan aturan-aturan tertentu. Dokumentasi dapat berupa tools helper ataupun hand out petunjuk penggunaan program. dll). kondisi awal dan kondisi akhir. Pseudecode berasal dari kata Pseudo yang artinya mirip atau imitasi atau menyerupai. Hal itu dapat terlihat di hampir semua perguruan tinggi atau sekolah menggunakan pemodelan algoritma Pseudecode dalam melakukan pendekatan terhadap code. install ulang. dan lain-lain. Di dalam pembelajaran ini pun kita menggunakan pemodelan Pseudecode. Dan akar kata kedua yaitu Code yang berarti program. Ada tiga tipe pemodelan. Notasi algoritmis yang ditulis didalam kurung kurawa {} maka tidak akan dieksekusi oleh compiler.masing perintah dalam penggunaan program. yaitu : 1.

Deskripsi merupakan bagian inti dari algoritma. fungsi dan prosedure. penamaan Pascal di ambil dari sebuah nama guru besar di Francis yaitu Blaise Pascal. Input(TheName). nama saya Pascal!”.„. TheName. {Judul/Header Program} { mencetak String “Hallo. Selamat Belajar Algoritma dan Pemrograman Menggunakan Bahasa Pascal‟). Output(„Oh! ‟. “Boleh kita berkenalan. biasa berisi intruksi-intruksi penyelesaian dan pemanggilan aksi tertentu yang sudah didefinisikan. Bahasa pemograman Pascal. Contoh: {Deskripsi} Output(‘Hallo. Siapa nama kamu?‟).TheName . Sebelum beranjak lebih jauh dan untuk mempermudah pelajaran selanjutnya.Contoh: Program Perkenalan. Contoh: {Deklarasi/Kamus} TheName:String. “Oh!. Dalam pembelajaran ini. konstanta). Output(‘Boleh kita berkenalan. notasi algoritma yang kita buat dengan model pseudecode akan kita konversikan ke dalam bahasa pemograman Pascal. variabel. {variabel penampung inputan bertipe data String} Deskripsi Bagian yang berisi uraian langkah-langkah penyelesaian masalah. Pascal termasuk ke dalam kategori bahasa pemograman prosedural yaitu suatu bahasa pemograman yang impelemtasinya berdasarkan kepada penyelesaian permasalahan . Selamat Belajar Algoritma dan Pemrograman Menggunakan Bahasa Pascal” ke piranti keluaran (monitor). Dan menerima inputan sebuah nama (TheName)dari user. Siapa nama kamu?”.} Deklarasi (Kamus) Bagian ini merupakan ruang untuk mendefinisikan beberapa komponen data (type data. sebaiknya kita bahas dulu apa itu bahasa pemograman Pascal. nama saya Pascal!‟).

Struktur Pascal terdiri dari beberapa bagian yang dimana tiap bagiannya sama dengan bagianbagian yang dimiliki oleh Algoritma-Pseudecode. 3. Namun kemudahan bahasa pemograman ini jika dibandingkan dengan bahasa pemogaman non-prosedural lainnya ialah mudah untuk dipelajari. Processor directive ini mengacu kepada library bawaan Pascal untuk melakukan standar baku pemograman. Kelemahan kategori ini akan terlalu banyak melibatkan coding dalam penggunaan fungsi dan prosedure dalam satu medan kerja untuk permasalahan yang kompleks dan sulit dalam pemeriksaan lebih lanjut terhadap pengembangan code-nya.yang mengandalkan langkah terurut dari beberapa fungsi dan prosedure program yang di definisikan. . Adapun struktur Pascal yang dimaksud yaitu: 1. Programe name dan Processor directive yang sama dengan judul program pada pseudecode. 2. { Preprocessor directives } USES crt. crt. Jika secara sederhana template dari struktur pascal tampak sebagai berikut: { Program name } PROGRAM my_program_1. Any_var : Real. Global variabel block merupakan kamus atau deklarasi dalam pseudecode. { Global Variable Block } VAR Int_var : Integer. khususnya bagi para pemula dalam mempelejari dan mengenal apa itu bahasa pemograman. String_var : String. { Main Procedure } BEGIN { Main procedure code } END. misal wincrt. namun untuk processor directive adalah key word wajib yang mesti dipanggil paling awal pada saat program di buat dan dijalankan. graphic dan lain-lain. Main procedure dan Main procedure code merupakan deksripsi dalam pseudecode.

Writeln(‘======================================’). . Output(‘Boleh kita berkenalan. Selamat Belajar Algoritma dan Pemrograman Menggunakan Bahasa Pascal‟).Contoh konversi pseudecode program perkenalan ke pascal Pseudecode Program Perkenalan. Output(„Oh! ‟. { Deskripsi } BEGIN Writeln(‘ Program Perkenalan ‘). USES crt.„. Input(TheName). {Judul/Header Program} {Deklarasi/Kamus} TheName:String. { Deklarasi } VAR TheName : String. Writeln. Siapa nama kamu?‟).TheName . {variabel penampung inputan bertipe data String} {Deskripsi} Output(‘Hallo. nama saya Pascal!‟). Pascal {judul program} PROGRAM perkenalan.

{Deskripsi} Input(f). {writeln: keyword keluaran dengan satu enter ke bawah} writeln(‘Boleh kita berkenalan. read(TheName).c:real. readln. nama saya Pascal!‟). c:=k*(f-kh). Siapa nama kamu?‟). {kamus} {nama tetapan} Const k=5/9.„.{proses konversi} Output(c).write(‘Hallo. LATIHAN  Program Konversi Suhu Farenhit ke Celcius Pseudecode {nama program} Program Konversi_Suhu. . {kh: konstanta suhu} {nama variable} var f. {write: keyword keluaran} writeln.TheName . {k: konstanta farenhit} Const kh=32. Selamat Belajar Algoritma dan Pemrograman Menggunakan Bahasa Pascal‟). {read: keyword untuk masukan} writeln(„Oh! ‟. {readln: keyword masukan dengan satu enter ke bawah} END.

Writeln(‘======================================’). {kamus} . var f.  Program Konversi Waktu (Jam ke Detik) Pseudecode {nama program} Program Konversi_Waktu. c:=k*(f-kh).readln(f). Write(‘Masukan Suhu dalam Farenheit: ‘). begin Writeln(‘Program Konversi Fareinheit Ke Celcius’). Const k=5/9.c:4:2).Pascal Program Konversi_Suhu. readln. Writeln.c:real. Writeln(‘Jadi Suhu Dalam Celcius Adalah: ‘. Writeln. Uses WinCrt. end. Const kh=32.

.’ Detik’). {deskripsi} Input(j). Writeln(‘Jadi Hasil Konversi : ‘. readln. Writeln. h:=(j*3600)+(m*60)+d. {jam} Input(m). {proses konversi} Output(h).d.readln(m). {detik} h:=(j*3600)+(m*60)+d. Write(‘Masukkan Jumlah Jam : ‘).m. Writeln(‘======================’). {detik akumulatif hasil konversi} Pascal Program Konversi_Waktu. Uses Wincrt.h:integer. Writeln.h. Var j.d. {menit} Input(d).m. Write(‘Masukkan Jumlah Detik : ‘).h:integer. Write(‘Masukkan Jumlah Menit : ‘).readln(j).readln(d). begin Writeln(‘Program Konversi Waktu’).j.

{kamus} var A.end.B). {deskripsi} Input(A). {proses tukar} C:=A. Output( A.C:integer.  Program Menukar Nilai Pseudecode {nama program} Program Menukar_Nilai. A:=B. B:=C. Uses WinCrt. Input(B).B.C:integer.WinDos. {keyword untuk membersihkan layar} .B. Pascal Program Menukar_Nilai. Begin Clrscr. var A.

A.  Program Hitung Karakter (Nama) Pseudecode {nama program} PROGRAM Hitung_Karakter. namalen : integer. End.B).readln(B).’ B=’. {kamus} nama : string. Writeln. {deskripsi} input (nama). readln.Writeln(‘Program Menukar Nilai A Menjadi B’). Writeln. Write(‘Masukkan Nilai A: ‘). C:=A. . A:=B. Writeln(‘=================================’). Write(‘Masukkan Nilai B: ‘).readln(A). B:=C. Writeln. Writeln(‘Hasil A=’.

{length: keyword untuk hitung karakter} writeln (‘Nama ‘. {length: keyword untuk hitung karakter} output (nama. Writeln. namalen : integer. USES crt. namalen). Pascal PROGRAM Hitung_Karakter.namalen := length(nama). END. namalen := length(nama). write (‘Masukan nama Anda? ‘).’ memiliki panjang karakter ‘. readln (nama). readln. VAR nama : string.  „Program Konversi Teks ke Uper ke Lower Pseudecode {nama program} . namalen). nama. Writeln(‘Program Hitung Karakter’). BEGIN clrscr. Writeln(‘=================================’).

USES crt. {deskripsi} input (text). BEGIN clrscr. output(text). . i : integer. {proses uper} text := upcase(text). Pascal PROGRAM convert_uper_lower. {kamus} text : string. Writeln(‘=======================================’). i : integer. Writeln(‘Program Konversi Teks ke Uper ke Lower’). {upcase: keyword untuk upercase karakter} output(text).PROGRAM convert_uper_lower. VAR text : string. {proses lower} text:= lowercase(text).

readln. readln. write (‘ ‘. . text).Writeln. readln (text). text). text:= lowercase(text). writeln (‘lowercase dari kalimat tersebut adalah: ‘). write (‘ ‘. writeln (‘Uppercase dari kalimat tersebut adalah: ‘). write (‘Masukan sebuah kalimat ‘). text := upcase(text). END.

Sign up to vote on this title
UsefulNot useful