Minggu, 15 Mei 2016

algoritma sorting

sorting C++

#selection sort

halo guys,, apa kabarr ni ??/,, gimana masih terus coding meskipun banyak tugas, dan selalau dalam tekanan tugas hahahaha,,, tenang tenang kita masih terus berjuang ya meskipun banyak halangan dan rintangan serta pengorbanan yang harus kita hadapii,,,,
kali ini mimin akan berbagi program sorting pada C++
 SORTING
apa itu sorting ?
          Sorting merupakan suatu proses untuk menyusun kembali humpunan obyek menggunakan aturan tertentu. Sorting disebut juga sebagai suatu algoritma untuk meletakkan kumpulan elemen data kedalam urutan tertentu berdasarkan satu atau beberapa kunci dalam tiap-tiap elemen. Pada dasarnya ada dua macam urutan yang biasa digunakan dalam suatu proses sorting: 


1. Urut naik (ascending)
   Mengurutkan dari data yang mempunyai nilai paling kecil sampai paling besar

2. Urut turun (descending)
   Mengurutkan dari data yang mempunyai nilai paling besar sampai paling kecil.

Mengapa harus melakukan sorting data? Ada banyak alasan dan keuntungan dengan mengurutkan data. Data yang terurut mudah untuk dicari, mudah untuk diperiksa, dan mudah untuk dibetulkan jika terdapat kesalahan. Data yang terurut dengan baik juga mudah untuk dihapus jika sewaktu-waktu data tersebut tidak diperlukan lagi. Selain itu, dengan mengurutkan data maka kita semakin mudah untuk menyisipkan data atapun melakukan penggabungan data.
Metode-metode sorting meliputi:

1. Insertion Sort (Metode Penyisipan)
2. Selection Sort (Metode Seleksi)
3. Bubble sort(Metode Gelembung)
4. Shell Sort (Metode Shell)
5. Quick Sort (Metode Quick)
6. Merge Sort (Metode Penggabungan) 


Analisis kasus :

Algoritma pengurutan dengan metode seleksi dapat diilustrasikan demikian. Misalkan diberikan data awal :
[8, 4, 7, 3, 1, 2, 6, 5]
Data pertama adalah 8. Akan dicari (atau tepatnya “dipilih/diseleksi”) data terkecil dari data kedua sampai terakhir yang terkecil untuk menempati posisi pertama (i=1) ini. Data terkecil ditemukan pada posisi ke-5 (t=5). Maka data pertama ditukar dengan data ke-5, menjadi :
[1, 4, 7, 3, 8, 2, 6, 5]
Langkah ini diulang untuk data kedua (i=2). Ditemukan data terkecil pada posisi ke-6 (t=6). Data ke-2 ditukar dengan data ke-6, menjadi :
Langkah ini diulang untuk data kedua (i=2). Ditemukan data terkecil pada posisi ke-6 (t=6). Data ke-2 ditukar dengan data ke-6, menjadi :
[1, 2, 73, 8, 4, 6, 5]
Fase selengkapnya dapat dilihat pada data berikut ini.
Data awal : [8, 4, 7, 3, 1, 2, 6, 5] 1 terkecil, 8ßà1
fase 1 [1, 4, 7, 3, 8, 2, 6, 5] 2 terkecil, 4ßà2
 fase 2 [1, 2, 7, 3, 8, 4, 6, 5] 3 terkecil, 7ßà3
 fase 3 [1, 2, 3, 7, 8, 4, 6, 5] 4 terkecil, 7ßà4
 fase 4 [1, 2, 3, 4, 8, 7, 6, 5] 5 terkecil, 8ßà5
 fase 5 [1, 2, 3, 4, 5, 7, 6, 8] 6 terkecil, 7ßà6
 fase 6 [1, 2, 3, 4, 5, 6, 7, 8] 7 terkecil, tetap
fase 7 [1, 2, 3, 4, 5, 6, 7, 8]
fase 8 [1, 2, 3, 4, 5, 6, 7, 8]

 terus bagaimana langkah-langkah nya :

bagai mana algoritmanaya :



Algoritma sorting data
{menyorting data dari kecil ke besar, algoritma menerima masukan yaitu batas(n) dan data,, menorting , lalu mencetak}
Procedure baca_data(int A[] ,int n){
Write A[i]
for i ß0,i<n,i++ than input A[i]
}

Procedure cetak_data(const int A[],int n){
for  i ß0,i<n,i++ than output A[i]
}

Procedure minimum(int A[], int dari, int n, int * tempat){
min ß A[dari]
*tempat ß dari
for i ßdari+1, i<n; i++ than do if A[i] < min
min ß A[i]
*tempat ß i
}
Procedure selection_sort(int A[], int n)
{
for i ß 0, i<n, i++
{ minimum(A, i, n, &t);
tukar(&A[i], &A[t]);
}
}


Deklarasi :
n, A[i]    : integer {input}
A[i]         : integer {output}

Deskripsi :
Read(n,A[i])
For iß0,i<n,i++
Than do sorting
Write(A[i])




 ,,,,,, langsung aja ya ,, kita simak ke codinganya......





#include <iostream>
#include <string>

using namespace std;
void baca_data(int A[], int n)
{ int i;
for (i = 0; i < n; i++)
{ cout << "Data ke- "<<i+1<<": ";
cin >> A[i];
}
}
void cetak_data(const int A[], int n)
{ int i;
for (i = 0; i < n; i++)
cout <<A[i]<<" ";
cout << "\n";
}
void tukar (int *a, int *b)
{ int temp;
temp = *a;
*a = *b;
*b = temp;
}
void minimum(int A[], int dari, int n, int * tempat)
{ int i, min;
min = A[dari];
*tempat = dari;
for (i = dari+1; i<n; i++)
if (A[i] < min)
{ min = A[i];
*tempat = i;
}
}
void selection_sort(int A[], int n)
{ int i, t;
for (i = 0; i<n; i++)
{ minimum(A, i, n, &t);
tukar(&A[i], &A[t]);
}
}
main() {
int data[10], n;
cout << "Banyak data : ";
cin >> n;
baca_data(data,n);
cetak_data(data,n);
selection_sort(data,n);
cetak_data(data,n);
return 0;
}

ada juga flowchart nya meskipun berbeda dengan c++,,, semoga bsa jadi refrensi



Jumat, 08 April 2016

Simulasi Membeli Bahan Bakar (SPBU/BBM).

Assalamu’alaikum w.w.,
Pada kesempatan ini saya akan memposting Program dari materi PERULANGAN (LOOP) , program ini akan dibuat dalam bentuk Flowchart dan C++ . Program yang akan di buat yaitu : Tentang Simulasi Membeli Bahan Bakar (SPBU/BBM).
Buat simulasi membeli bahan bakar dengan spesifikasi :
  1. Input berupa :
    1. uang/berapa liter yang akan dibeli
    2. Jenis bahan bakar yang akan dibeli
  2. Indikator akan berlangsung terus (kenaikkan 0.1liter) selama total harga/jumlah liter bahan bakar yang dibeli belum melebihi permintaan
  3. Output menyatakan :
    1. Jumlah liter yang dibeli (bila input berupa uang)
Total uang yang harus dibayar (bila input berupa liter)

 Berikut ini adalah Gambar Program Flowchart yang menggunakan Aplikasi RAPTOR :



Outputnya :
1. Bensin
2. Pertamax
3. Solar

Dan yang ini Gambar Program C++ yang Menggunakan Aplikasi Dev C++ :
#include <iostream>
#include <string>
#include <cstdlib>
#include <math.h>

/* run this program using the console pauser or add your own getch, system("pause") or input loop */

using namespace std;

   class BBM {
   private:
   float uang, pilihan;
   double hasil1,hasil2,hasil3;
   public:
     void Set_Pilihan(){
         cout<<"\t\t\t  |      SPBU BARU       |"<<endl;
         cout<<"\t\t\t  ========================"<<endl<<endl;
         cout<<"\t\t\t\tPilihan Jenis BBM"<<endl<<endl;
         cout<<" 1. Bensin"<<endl;
         cout<<" 2. Solar"<<endl;
         cout<<" 3. Pertamax"<<endl;
         cout<<"\n\nMasukkan Urutan Pilihan Jenis BBM 1..3 : ";
         cin>>pilihan;

       if (pilihan==1){
          cout<<" 1. Bensin"<<endl;
          cout<<"\nMasukkan Uang Anda : ";
          cin>>uang;
          hasil1=uang/4500;
          for (double i=0.1; i<=hasil1; i=i+0.0001){
          cout<<i<<endl<<endl;
          }
          cout<<" Bensin Yang Anda Dapat :"<<hasil1<<" "<<"liter"<<endl;
          }
       if (pilihan==2){
          cout<<" 2. Solar"<<endl;
          cout<<"\nMasukkan uang anda :";
          cin>>uang;
          hasil2=uang/4200;
          for (double j=0.1; j<=hasil2; j=j+0.0001){
          cout<<j<<endl;
          }
          cout<<" Bensin Yang Anda Dapat :"<<hasil2<<" "<<"liter"<<endl;
          }
       if (pilihan==3){
          cout<<" 3. Pertamax"<<endl;
          cout<<"\nMasukkan Uang Anda :";
          cin>>uang;
          hasil3=uang/7000;
          for (double k=0.1; k<=hasil3; k=k+0.0001){
          cout<<k<<endl;
          }
          cout<<" Bensin Yang Anda Dapat :"<<hasil3<<" "<<"liter"<<endl;
          }
         }
       };

int main(int argc, char** argv) {
      int x;
      BBM B;
      B.Set_Pilihan();
      cin>>x;
     
    return 0;
}




Output/hasil compiler dari program tersebut :
 




Transaksi Buku Tabungan.

Assalamu’alaikum w.w.,
Pada kesempatan ini saya akan memposting Program Transaksi Buku Tabungan. Dari masalah yang ada di bawah ini :

Periksa buku tabungan salah satu anggota kelompok. Lakukan detail transaksi pengambilan uang tabungan termasuk detail isian dalam formulir transaksi.
pisahkan algoritma penulisan angka menjadi ejaan :
Misal anda mengambil uang sebesar 300.000 akan tertulis sebagai "Tiga ratus ribu rupiah"
tulislah menggunakan huruf miring (italic) bila pernyataan tertentu boleh berada pada deretan lain. sementara urutan yang HARUS berada pada urutan tertentu tulis dalam huruf tegak (biasa).

Berikut ini adalah Gambar Program Flowchart yang menggunakan Aplikasi RAPTOR :

Kasus 2.3 : Program untuk menghitung konversi dari m ke cm dan inchi



Assalamu’alaikum w.w.,
 Hallo semua .... 
Pada kesempatan ini saya akan memposting Program Flowchart yaitu program yang berupa :
Program untuk menghitung konversi dari m ke cm dan inchi , yang memiliki Input : misalkan m (mewakili meter) dan Proses : 1 meter = 100 cm, inci = 2.54 cm , cm = m *100, inci  = m*100/ 2.54 .

Analisis : 
- Input : Misalkan m (mewakili meter)
- Proses : 1 meter = 100 cm
                1 inchi = 2.54 cm
                cm=m*100
                inchi=m*100/2.54
- Output : Tulis (cm, inchi)

Algoritma :
- Deklarasi   : - m, cm, inchi = float
                       - hasil=float 
- De  skripsi : - Read (m)
                       - cm=m*100  
                       - inchi=m*100/2.54
 

 Berikut ini adalah Gambar Programnya yang menggunakan Aplikasi RAPTOR :

 
 Output/hasil compiler dari program tersebut :
   Hasil Outputnya ini saya memasukkan nilsi m = 4 m , maka Outputnya akan mengeluarkan cm = 400 cm , dan inchi = 157.4803 inchi.

Berikut ini adalah Gambar Programnya yang menggunakan Aplikasi Dev C++ :


 Output/hasil compiler dari program tersebut :
   Hasil Outputnya ini saya memasukkan nilsi m = 4 m , maka Outputnya akan mengeluarkan cm = 400 cm , dan inchi = 157.4803 inchi.

Kasus 2.2 : Program untuk mencari hasil kali dari dua buah bilangan



Assalamu’alaikum w.w.,
 Hallo semua .... 
Pada kesempatan ini saya akan memposting Program Flowchart yaitu program yang berupa :
Program untuk mencari hasil kali dari dua buah bilangan, yang memiliki Input : misalkan a, b semua integer.

Buat algoritma dan program untuk mencari hasil kali dua buah bilangan.
Analisis :
- Input    : Misalkan a,b semua integer
- Proses : hasil <=a*b
- Output : Tulis (hasil)

Algoritma :
- Menerima Inputan dari krdua bilangan
Mengalihkan kedua bilangan tersebut
- Menampilkan hasil perkalian dari kedua bilangan


  
Berikut ini adalah Gambar Programnya yang menggunakan Aplikasi RAPTOR :


 Output/hasil compiler dari program tersebut :
   Hasil Outputnya dari hasil Perkalian Angka : 7*8 = 56


Berikut ini adalah Gambar Programnya yang menggunakan Aplikasi Dev C++ :

#include <iostream>
#include <cstdlib>

/* run this program using the console pauser or add your own getch, system("pause") or input loop */

using namespace std;

int main(int argc, char** argv) {
    int a,b,jumlah;
   
    cout<<"Masukkan = ";cin>>a;
    cout<<"Masukkan = ";cin>>b;
    jumlah=a*b;
    cout<<"Hasil = "<<jumlah;
   
    return 0;
}


 Output/hasil compiler dari program tersebut :
   Hasil Outputnya dari hasil Perkalian Angka : 7*8 = 56

Kasus 2.1 : Program untuk mencari jumlah dari 3 buah bilangan bulat



Assalamu’alaikum w.w.,
  Hallo semua .... 
Pada kesempatan ini saya akan memposting Program Flowchart yaitu program yang berupa : Program untuk mencari jumlah dari 3 buah bilangan bulatt.


Hitunglah jumlah dari 3 buah bilangan bulat.
Analisis :
- Input   : Misalkan a, b, c semua integer
- Proses : jumlah <=a+b+c
Output   : Tulis (jumlah)

 Algoritma :
- Menerima Input dari 3 bilangan bulat
- Menjumlahkan Ketiga bilangan tersebut 
- Lalu mencetak hasil penjumlahannya
  

Berikut ini adalah Gambar Programnya yang menggunakan Aplikasi RAPTOR :


 Output/hasil compiler dari program tersebut :
   Hasil Outputnya dari hasil Penjumlahan Angka : 4+6+8 = 18



Berikut ini adalah Gambar Programnya yang menggunakan Aplikasi De v C++ :
#include <iostream>
#include <cstdlib>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
using namespace std ;
int main(int argc, char** argv) {
            int a,b,c,jumlah;
   
            cout<<" Masukkan Angka 1 : ";
    cin>>a;
    cout<<" Masukkan Angka 2 : ";
    cin >> b;
    cout<<" Masukkan Angka 3 : ";
    cin>>c;
    cout<<endl;
    jumlah =(a+b+c);
    cout<<"Jumlah 3 Buah Bilangan : "<<jumlah;
           
            return 0;
}

Output/hasil compiler dari program tersebut :

bab 6

bab 6 https://drive.google.com/open?id=0BzL9pJeEU3V6T0Z6eUdSVThnN1E