Sabtu, 11 Juni 2016

LAPORAN MODUL 2 PRAKTIKUM ALGORITMA DAN STRUKTUR DATA STACK




LAPORAN MODUL 2
PRAKTIKUM ALGORITMA DAN STRUKTUR DATA
STACK
Disusun Untuk Memenuhi Mata kuliah Praktikum Algoritma Dan Struktur Data
Yang Di Bimbing Oleh Haikal Nando Winata, ST. MIT




oleh :
FRANHORAS SAMOSIR
15210066


JURUSAN TEKNIK INFORMATIKA
FAKULTAS TEKNOLOGI INDUSTRI
INSTITUT TEKNOLOGI MEDAN
TA 2015-2016




PERCOBAAN PRATIKUM

·         Source Code :

#include <cstdlib>
#include <string>
#include <iostream>

using namespace std;

int top=-1;
char stack[128];//asumsi max stack 100
char x;

void push()
{
     cout<<"masukkan satu karakter: ";
     cin>>x;
     top++;
     stack[top]=x;
     }

void pop()
{
     if(top<0)
     {
              cout<<"stack kosong"<<endl;
              return;
              }

     x=stack[top];
     top--;
     cout<<"karakter yang di 'POP' adalah "<<x<<endl;
     }

void cetak()
{
     if(top<0)
     {
              cout<<"stack kosong" <<endl;
              return ;
              }

int i=0;
for(i=top;i>=0;i--)
cout<<stack[i]<<endl;
}

int main(int argc, char *argv[])
{
    int input;
    cout<<"MASUKKAN PILIHAN: "<<endl;
    cout<<"\tpush=1"<<endl;
    cout<<"\tpop=2"<<endl;
    cout<<"\tcetak=3"<<endl;
    cout<<"\tquit=4"<<endl;
    while(true)
    {
               cout<<"\nMasukan pilihan: ";
               cin>>input;
               if(input==1)
               {push();}
               else if(input==2)
               {pop();}
               else if(input==3)
               {cetak();}
               else if(input==4)
               {break;}
               else
               {
                   cout<<"Perintah ' "<<input<<" tidak dikenal"<<endl;
                   }
                   }

    system("PAUSE");
    return EXIT_SUCCESS;
}

TUGAS PRATIKUM

1. Sebuah plasa mempunyai ruang parkir yang agak unik yaitu hanya mempunyai sebuah jalur. Jalur tersebut hanya bisa diisi sampai 30 mobil saja. Mobil yang datang lewat salah satu jalur (sebut saja A), sedang mobil yang akan keluar lewat jalur lainnya (sebut saja B). Jika ada sebuah mobil yang akan keluar dan kebetulan berada di tengah, maka mobil-mobil lain yang berada didepannya harus dipindahkan dulu, setelah mobil tersebut keluar maka mobil-mobil yang dipindahkan tadi disusun kembali seperti semula. Jika mobil yang akan masuk, tetapi jalur parkir sudah penuh maka ada pesan “Parkir penuh!”.

·         Source Code :

#include<iostream>
#include<stdio.h>
#include<conio.h>
#define max 10
using namespace std;
struct tumpukan{
            int pertama;
            int tmp[max];
            }x;
            void awal()
            {
                        x.pertama=-1;
            }
            int kosong()
            {
                        if (x.pertama==-1)
                        return 1;
                        else
                        return 0;
            }
            int penuh(){
                        if (x.pertama==max-1)
                        return 1;
                        else
                        return 0;
            }
            void input(int data){
                        if (kosong()==1)
                        {x.pertama++;
                        x.tmp[x.pertama]=data;
                        cout<<"mobil "<<x.tmp[x.pertama]<<"Telah Masuk ke Dalam Parkiran";}
                        else if (penuh()==0)
                        {x.pertama++;
                        x.tmp [x.pertama]=data;
                        cout<<"mobil " <<x.tmp[x.pertama]<<"Telah Masuk ke Dalam Parkiran";}
                        else
                        cout<<"Tumpukan Dalam Parkiran Penuh";
            }
            void hapus(){
                        if (kosong()==0){
                                    cout<<"Mobil Paling Atas Sudah Terambil";
                                    x.pertama--;
                        }
                        else
                        cout<<"PARKIRAN KOSONG";
            }
            void tampil(){
                        if (kosong()==0){
                                    for(int i=x.pertama;i>=0;i--)
                                    {cout<<"\n Mobil ke "<<i<<" ="<<x.tmp[i];}
                                    }
                                    else
                                    cout<<"TUMPUKAN DALAM PARKIR KOSONG";
                        }
                        main(){
                                    int pilih,data;
                                    awal();
                                    do
                                    {
                                    system("CLS");
                                    cout<<"========MENU PROGRAM=======\n\n";
                                    cout<<"1.Input Data Mobil Pada Stack"<<endl;
                                    cout<<"2.Hapus Data Mobil Pada Stack"<<endl;
                                    cout<<"3.Tampil data Parkiran"<<endl;
                                    cout<<"4.keluar\n\n";
                                    cin>>pilih;
                                    cout<<endl;
                                    switch (pilih)
                                    {case 1:cout<<"Masukan Mobil Ke Dalam Stack =";cin>>data;
                                    input(data);
                                    break;
                                    case 2:hapus();
                                    break;
                                    case 3:tampil();
                                    break;
                                    case 4: cout<<"Tekan enter untuk keluar";
                                    }getch();}
                                    while(pilih!=4);
                        }


·      Running Program :

Gambar memasukan data mobil pada stack


Gambar menampilkan data parkiran

Gambar menghapus data mobil pada stack


Gambar menampilkan data parkiran


3. Buatlah program animasi stack. Gambarkan sebuah wadah dan beri tiga pilihan : push, pop dan quit. Jika dipilih push, program akan meminta user menginputkan sebuah karakter yang akan dimasukkan ke wadah tersebut. (maksimal 10 karakter dalam wadah). Jika dipilih pop maka karakter teratas akan dikeluarkan dari wadah. Jika dipilih quit maka program selesai.
·         Source Code :
#include <cstdlib>
#include <string>
#include <iostream>

using namespace std;

int top=-1;
char stack[100];//asumsi max stack 100
char x;

void push()
{
     cout<<"masukkan satu karakter: ";
     cin>>x;
     top++;
     stack[top]=x;
     }

void pop()
{
     if(top<0)
     {
              cout<<"stack kosong"<<endl;
              return;
              }

     x=stack[top];
     top--;
     cout<<"karakter yang di 'POP' adalah "<<x<<endl;
     }

void cetak()
{
     if(top<0)
     {
              cout<<"stack kosong" <<endl;
              return ;
              }

int i=0;
for(i=top;i>=0;i--)
cout<<stack[i]<<endl;
}

int main(int argc, char *argv[])
{
    int input;
    cout<<"Nama : FRANHORAS SAMOSIR||\n";
    cout<<"NIM  : 15210066          ||\n";
    cout<<"=========================||\n\n";
    cout<<"\n\t''PROGRAM STACK''\n\n";
    cout<<"====================================\n";
    cout<<"\nMENU PILIHAN : "<<endl;
    cout<<"\tpush  = 1 (Masukan data)"<<endl;
    cout<<"\tpop   = 2 (Hapus data)"<<endl;
    cout<<"\tcetak = 3 (Menampilkan data)"<<endl;
    cout<<"\tquit  = 4 (Keluar)"<<endl;
    while(true)
    {
               cout<<"\nMasukan pilihan anda....";
               cin>>input;
               if(input==1)
               {push();}
               else if(input==2)
               {pop();}
               else if(input==3)
               {cetak();}
               else if(input==4)
               {break;}
               else
               {
                   cout<<"Perintah ' "<<input<<" tidak dikenal"<<endl;
                   }
                   }

    system("PAUSE");
    return EXIT_SUCCESS;
}

·      Running Program :

Gambar Memasukkan data stack


Gambar memampilkan data stack


Gambar menghapus data stack


Tidak ada komentar:

Posting Komentar