Ide Membuat Program Konversi Bilangan Biner ke Desimal
March 24th, 2009 | by rosihanari |
Cetak Artikel Ini
Setelah beberapa waktu yang lalu saya memposting artikel tentang bagaimana membuat program konversi bilangan desimal ke biner, sekarang saya coba untuk membuat artikel kebalikannya.
Dalam judul ini sengaja saya kasih embel-embel ‘ide’ karena memang fokus dari artikel ini adalah menggambarkan idenya, dan bukan hanya sekedar menampilkan programnya saja.
OK.. misalkan diberikan sebuah bilangan biner atau bilangan berbasis dua 10110. Apakah Anda mengetahui konsep untuk mengkonversinya ke bentuk desimal atau bilangan berbasis 10? Anda mungkin telah mengetahui konsepnya ketika di perkuliahan. Bagi yang belum mengetahui, berikut ini adalah proses konversinya:
(10110)2 = 1×24 + 0×23 + 1×22 + 1×21 + 0×20
(10110)2 = 16 + 0 + 4 + 2 + 0 = 22
Dengan demikian hasil konversi bilangan biner 10110 ke desimal adalah 22.
Bila kita lihat dari contoh di atas, maka sebenarnya terdapat proses yang diulang-ulang dalam mengkonversi n digit bilangan biner yaitu menghitung bi x 2i, dengan i = n-1, n-2, n-3, …, 0 dan bi adalah digit biner ke-i. Selain menghitung bi x 2i, terdapat proses lain yang diulang-ulang yaitu menjumlahkan bi x 2i untuk setiap i.
Nah… berdasarkan konsep tersebut, OK… kita sudah mendapatkan idenya. Karena terdapat sesuatu yang diulang maka ketika kita akan membuat program untuk mengkonversinya, kita akan menggunakan looping yang dalam hal ini akan digunakan i sebagai counternya.
Namun… jika kita lihat konsep di atas, maka nilai i dimulai dari n-1, selanjutnya n-2 dst… sampai 0. Dengan kata lain, kita terlebih dahulu harus mengetahui nilai n nya yang dalam hal ini merupakan jumlah digit biner. Bagaimana cara mengetahuinya? Hmmm… Anda dapat dengan mudah mengetahuinya apabila bilangan binernya disajikan dalam bentuk tipe data string. Dengan demikian Anda bisa menggunakan function length() untuk mendapatkan panjang stringnya
OK… we’ve got it… now let’s get into PASCAL program..
program konversiBiner2Dec; var bilBiner : string; { function untuk menghitung a pangkat b} function pangkat(a, b : integer) : integer; var i, hasil : integer; begin hasil := 1; for i:=1 to b do begin hasil := hasil * a; end; pangkat := hasil; end; { function untuk menghitung konversi biner ke desimal } function bin2Dec(biner : string) : integer; var n, sum, i : integer; begin n := length(biner); sum := 0; for i:= n-1 downto 0 do begin if (biner[n-i] = '0') then sum := sum + 0 * pangkat(2, i) else if (biner[n-i] = '1') then sum := sum + 1 * pangkat(2, i); end; bin2Dec := sum; end; begin bilBiner := '10110'; write('Bilangan desimalnya : ', bin2Dec(bilBiner)); end.
Catatan:
Anda juga dapat mengubah blok for dalam function bin2Dec() menjadi seperti ini
for i:= n-1 downto 0 do begin if (biner[n-i] = '0') then sum := sum; else if (biner[n-i] = '1') then sum := sum + pangkat(2, i); end;
Mengapa demikian? Ya… karena ketika digit binernya 0, maka hasil jumlahannya tetap (tidak terpengaruh) sebagai akibat dari hasil perkalian 0 * pangkat(2, i) = 0.
OK.. demikian sedikit penjelasan mengenai bagaimana ide membuat program konversi dari biner ke desimal. Mudah-mudahan artikel ini bermanfaat bagi Anda dalam mencari ide membuat konversi bilangan basis yang lain ke desimal.
Beberapa artikel terkait
- Membuat Program Konversi Bilangan Desimal ke Biner dengan Pascal
- Ide Membuat Program Mengecek Bilangan Prima
- Function Menghitung Pangkat Bilangan dengan Pascal
- Mengatur Digit Desimal Bilangan Real di PHP
- Tentang Recursive Function
- Memformat Bilangan dengan Function number_format()
- Pembahasan Soal Olimpiade Komputer Kabupaten #2
- Rahasia Dibalik Cara Pembuatan Program Tebak Angka
- Teknik Debugging Dalam Membuat Program
- Apa Sih Gunanya Function??
Share this article on:
Kata kunci: biner - desimal - konversi - pascal -
Mau kaos (T-shirt) Wordpress keren? (


Rosihan Ari adalah seorang programmer, penulis buku, trainer, peneliti dan berusaha menjadi seorang blogger sejati dengan memberikan yang terbaik buat negeri ini. Berfokus pada computer programming serta computer aided learning for mathematics, ia ingin berbagi ilmu yang dimilikinya. 


menurut saya program anda sudah baik. tolong kirimkan saya program konversi yang lainya karna saya ingin mempelajari yang lain nya. di tunggu balasanya
menurut saya program yang anda buat cukup baik, bagaimana bila angka tersebut terdiri dari koma dan pecahan ???
maaf sebelumnya dan terima kasih atas balasannya
Bisa tolong buatin program könvrsi angka ke kalimat ga kang, misal 25=dua puluh lima
@aan: oh… ini dia nih artikelnya http://blog.rosihanari.net/ide-dibalik-pembuatan-script-membilang-bilangan, kali lain coba disearch dulu deh di blog ini. OK?
kk saya mau nanya tentang cara apa saja yang digunakan pada awal sampai akhir pembuatan konversi image ke word soalnya saya mau skripsi n rencananya saya mau ngmbil judul seperti itu tapi apakah butuh waktu yang lama untuk menyelesaikannya sedangkan saya masih tahap belajar……tolong bantuannya y kk
thanx…..blas di email saya ja y kk (rizqi_jailani@yahoo.co.id)
@rizqi: wah saya belum tahu kisaran lama atau tidaknya mas. Tapi yang jelas modal dasarnya anda harus memahami konsep edge detection dulu.
trus apakah sistem tersebut memakai algoritma dan metode untuk proses konversinya….tolong y kk penjelasannya
thanx…..
@rizqi: oh… kalo algoritma itu jelas pakai mas… membuat program tanpa algoritma itu tidak akan pernah bisa. Mungkin anda bertanya, lho lantas algoritmanya yang mana? algoritmanya ya.. ide pembuatan programnya itu (langkah-langkah penyelesaian masalah)
oiy kk saya masih krang mengerti tntang algoritma n metode yg digunakan…bleh mnta contoh dari hasil yg anda perna gunakan gak,soalnya saya masih bngung (maaf y klo saya bnyak tanya soalnya saya masih baru belajar)
thanx………
Mas cara belajar algoritma biar cepet bisa gmn??
d bls ke emailq aja mas..
Makasih…