Menghilangkan duplikasi
Latihan No 3 :1. Mengidentifikasi Masalah :
=> Menghilangkan duplikasi dari data yang diinputkan.
2. Menentukan Input dan Output :
=> input : a
output : n
3. Membuat Flowchart :
4. Test Menggunakan Data :
data awal
A=A[n]
b=B[n]
data baru
A[n]=A[n-1]
5. Implementasi C++ :
#include <iostream>
#include <cstdlib>
#include <string>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
using namespace std;
class Array1D{
friend ostream& operator<<(ostream&, const Array1D&);
friend istream& operator>>(istream&, Array1D&);
public:
Array1D();
void cetak();
void geser_kiri();
void geser_kanan();
void hapus_elemen();
private:
char A[5];
int posisi;
};
Array1D::Array1D(){
for(int i=0;i<5;i++)
A[i]='O';
}
void Array1D::cetak(){
for(int i=0;i<5;i++)
cout<<A[i]<<" ";
}
ostream& operator<<(ostream& out, const Array1D& x){
for(int i=0;i<5;i++)
out<<x.A[i]<<" ";
out<<endl;
return out;
}
istream& operator>>(istream& in, Array1D& x){
int posisi;
for (int posisi=1; posisi<=5; posisi++){
cout<<"\nMasukkan Nilai Array Posisi Ke- : ";
in>>x.posisi;
if(posisi >= 0 && posisi <= 5){cout<<"Masukkan Elemen Array : ";
in>>x.A[posisi-1];
}
}
return in;
}
void Array1D::geser_kanan(){
int n=5;
int temp=A[n-1];
for(int i=n-1;i>=0;i--)
A[i+1]=A[i];
A[0]=temp;
}
void Array1D::geser_kiri(){
int n=5;
int temp=A[0];
for(int i=0;i<n;i++)
A[i]=A[i+1];
A[n-1]=temp;
}
void Array1D::hapus_elemen(){
int posisi;
cout<<"Pilih Indeks Berapa Yangg akan Di Hapus : ";
cin>>posisi;
if(posisi>0 && posisi<=5)
A[posisi-1]='O';
else cout<<"Indeks yang Anda Masuukan Salah Karena Indek Hanya Terdiri Dari 1 - 5\n";
}
int main(int argc, char *argv[]){
Array1D x;
cout<<"\t\t\tArray Masih Kosong : "<<x;
cin>>x;
cout<<"\nIsi Array Saat ini : "<<x;
x.geser_kiri();
cout<<"Isi Array Setelah di Geser Kiri : "<<x;
x.geser_kanan();
cout<<"Isi Array Setelah di Geser Kanan : "<<x;
cout<<"\nUrutan Elemen Pada Indeksnya Saat ini : "<<x;
x.hapus_elemen();
cout<<"\nSetelah dihapus Menjadi : "<<x;
system("PAUSE");
return 0;
}
6. Execusi :
0 komentar:
Posting Komentar