#include <iostream.h>
#include <stdlib.h>
#include <malloc.h>
#include <conio.h>
#define Nil NULL
#define info(P) P->info
#define next(P) P->next
#define First(L) (L)
typedef int InfoType;
typedef struct telmlist *address;
typedef struct telmlist
{
InfoType info;
address next;
}elmtlist;
typedef address list;
void CiptaSenarai(list *L)
{
First(*L) = Nil;
}
list NodBaru(int m)
{
list n;
n = (list) malloc(sizeof(elmtlist));
if (n !=NULL)
{
info(n) = m;
next(n) = Nil;
}
return n;
}
void SisipSenarai (list *L, list t, list p)
{
if (p == Nil)
{
t->next = *L;
*L = t;
}
else
{
t->next = p->next;
p->next = t;
}
}
void CetakSenarai (list L)
{
list ps;
for (ps=L; ps!=Nil; ps=ps->next)
{
cout<<" "<<info(ps)<<" -->";
}
cout<<" NULL"<<endl;
}
InfoType Max(list L)
{
address Pmax,Pt;
Pmax = First(L);
if (next(Pmax) == Nil)
{
return (info(Pmax));
}
else
{
Pt = next(Pmax);
while (Pt != Nil)
{
if (info(Pmax) < info(Pt))
{
Pmax = Pt;
}
else
{
Pt = next(Pt);
}
}
return (info(Pmax));
}
}
InfoType Min(list L)
{
address Pmin,Pt;
Pmin = First(L);
if (next(Pmin) == Nil)
{
return (info(Pmin));
}
else
{
Pt = next(Pmin);
while (Pt != Nil)
{
if (info(Pmin) > info(Pt))
{
Pmin = Pt;
}
else
{
Pt = next(Pt);
}
}
return (info(Pmin));
}
}
void main()
{
list pel;
list n;
int i,k,nilai,maks,min;
CiptaSenarai(&pel);
cout<<"Masukkan Banyak Data = ";
cin>>k;
for (i=1; i<=k; i++)
{
cout<<"Masukkan Data Senarai ke-"<<i<<" = ";
cin>>nilai;
n = NodBaru(nilai);
SisipSenarai (&pel, n, NULL);
}
cout<<endl;
CetakSenarai(pel);
maks = Max(pel);
min = Min(pel);
cout<<endl;
cout<<"Nilai terbesar : "<<maks;
cout<<endl;
cout<<"Nilai Terkecil : "<<min;
getch();
}
Hasilnya inputkan data sendiri ya???? hhehee
Tidak ada komentar:
Posting Komentar