program meng-konversikan bilangan heksadesimal (basis 16)
menjadi bilangan biner (basis 2)
uses crt;
var
hexa : string;{variable for storing hexa input}
biner : string;{variable for storing binary output}
desimal : integer;{temporary variable for decimal conversion}
index,conv,sub : integer;{variable for looping and subtractor}
BEGIN
clrscr;{clearing the screen}
{ask for hexa input and read the input}
write('Input on Hexa : ');readln(hexa);
{primary loop converter hexa to binary}
for index:=1 to length(hexa) do
begin
{case of hexa written on numeric character}
if (ord(hexa[index])>=ord('0')) and (ord(hexa[index])<=ord('9')) then begin {ascii code of hexa - ascii code of '0'} desimal:=ord(hexa[index])-ord('0'); end else {case of hexa written on uppercase letter} if (ord(hexa[index])>=ord('A')) and (ord(hexa[index])<=ord('F')) then begin {ascii code of hexa - ascii code of 'A'+10} {A represent 10 on decimal} desimal:=ord(hexa[index])-ord('A')+10; end else {case of hexa written on lowercase letter} if (ord(hexa[index])>=ord('a')) and (ord(hexa[index])<=ord('f')) then begin {ascii code of hexa - ascii code of 'a'} desimal:=ord(hexa[index])-ord('a')+10; end else {case of the input is wrong} begin writeln('INPUTAN SALAH!!'); readln; {terminate the program immediately} exit; end; writeln('BINARY'); {the subtractor start on 8 (2^3)} sub:=8; for conv:=3 downto 0 do begin {the decimal bigger than subtractor} if (desimal>=sub) then
begin
write('1');
{subtract the decimal with subtractor}
desimal:=desimal-sub;
end
else
begin
{write 0 and do nothing}
write('0');
end;
{decrement the power of subtractor by 1}
sub:=sub div 2;
end;
{just for separating output per character}
write(' ');
end;
readln;
END.
Thursday, February 28, 2008
Hexadecimal to Binary Converter (Pascal)
Monday, February 18, 2008
Selection Sort (C)
program untuk sorting data menggunakan algoritma seleksi
atau sering disebut selection sort#include "stdio.h"
main()
#include "conio.h"
{
int data[10] = {22,2,5,7,9,0,32,34,37,56},x;
for (int index=0;index<=9;index++)
{
printf("%3d",data[index]);
}
for (int index=0;index<9;index++)
{
int x=index;
for(int index2=index+1;index2<=9;index2++)
{
if(data[x]>data[index2])
{
x=index2;
}
}
int trans=data[index];
data[index]=data[x];
data[x]=trans;
}
printf("\n\n");
for (int index=0;index<=9;index++)
{
printf("%3d",data[index]);
}
getch();
}
Tower of Hanoi (C)
program untuk menyelesaikan permasalahan tower of hanoi
dimana keping pada tiang pertama harus dipindah ke tiang ketiga
dengan bantuan satu tiang bantu
dengan syarat keping yang lebih besar tidak boleh berada di atas
keping yang lebih kecil#include "stdio.h"
#include "conio.h"
void pindah(int jumlah, char asal, char bantu, char tujuan)
{
if (jumlah==0)
{
return;
}
else
{
pindah(jumlah-1,asal,tujuan,bantu);
printf("%c KE %c\n",asal,tujuan);
pindah(jumlah-1,bantu,asal,tujuan);
}
}
main()
{
int jumlah;
printf("Masukkan jumlah piringan : ");
scanf("%d",&jumlah);
pindah(jumlah,'A','B','C');
getch();
}
Subscribe to:
Posts (Atom)