Python - Desain Algoritma

Algoritma adalah prosedur langkah demi langkah, yang mendefinisikan sekumpulan instruksi yang akan dieksekusi dalam urutan tertentu untuk mendapatkan keluaran yang diinginkan. Algoritme umumnya dibuat secara independen dari bahasa yang mendasarinya, yaitu algoritme dapat diterapkan di lebih dari satu bahasa pemrograman.

Dari sudut pandang struktur data, berikut adalah beberapa kategori penting dari algoritma -

  • Search - Algoritma untuk mencari item dalam struktur data.

  • Sort - Algoritma untuk mengurutkan item dalam urutan tertentu.

  • Insert - Algoritma untuk memasukkan item ke dalam struktur data.

  • Update - Algoritma untuk memperbarui item yang ada dalam struktur data.

  • Delete - Algoritma untuk menghapus item yang ada dari struktur data.

Karakteristik Algoritma

Tidak semua prosedur bisa disebut algoritma. Algoritme harus memiliki karakteristik berikut -

  • Unambiguous- Algoritma harus jelas dan tidak ambigu. Setiap langkah (atau fase), dan masukan / keluarannya harus jelas dan hanya mengarah pada satu makna.

  • Input - Algoritme harus memiliki 0 atau lebih input yang terdefinisi dengan baik.

  • Output - Algoritme harus memiliki 1 atau lebih keluaran yang terdefinisi dengan baik, dan harus cocok dengan keluaran yang diinginkan.

  • Finiteness - Algoritme harus dihentikan setelah sejumlah langkah terbatas.

  • Feasibility - Harus layak dengan sumber daya yang tersedia.

  • Independent - Algoritme harus memiliki petunjuk langkah demi langkah, yang harus independen dari kode pemrograman apa pun.

Bagaimana Cara Menulis Algoritma?

Tidak ada standar yang didefinisikan dengan baik untuk penulisan algoritma. Sebaliknya, ini tergantung pada masalah dan sumber daya. Algoritma tidak pernah ditulis untuk mendukung kode pemrograman tertentu.

Seperti yang kita ketahui bahwa semua bahasa pemrograman berbagi konstruksi kode dasar seperti loop (do, for, while), flow-control (if-else), dll. Konstruksi umum ini dapat digunakan untuk menulis algoritme.

Kami menulis algoritme secara selangkah demi selangkah, tetapi tidak selalu demikian. Penulisan algoritme adalah proses dan dijalankan setelah domain masalah didefinisikan dengan baik. Artinya, kita harus mengetahui domain masalahnya, untuk itu kita sedang merancang solusinya.

Contoh

Mari kita coba belajar penulisan algoritma dengan menggunakan sebuah contoh.

Problem - Rancang algoritma untuk menambahkan dua angka dan menampilkan hasilnya.

step 1 − START
step 2 − declare three integers a, b & c
step 3 − define values of a & b
step 4 − add values of a & b
step 5 − store output of step 4 to c
step 6 − print c
step 7 − STOP

Algoritme memberi tahu pemrogram cara membuat kode program. Alternatifnya, algoritme dapat ditulis sebagai -

step 1 − START ADD
step 2 − get values of a & b
step 3 − c ← a + b
step 4 − display c
step 5 − STOP

Dalam desain dan analisis algoritma, biasanya metode kedua digunakan untuk mendeskripsikan suatu algoritma. Ini memudahkan analis untuk menganalisis algoritme yang mengabaikan semua definisi yang tidak diinginkan. Dia dapat mengamati operasi apa yang digunakan dan bagaimana prosesnya mengalir.

Penulisan step numbers, bersifat opsional.

Kami merancang algoritme untuk mendapatkan solusi dari masalah tertentu. Sebuah masalah dapat diselesaikan dengan lebih dari satu cara.

Karenanya, banyak algoritma solusi dapat diturunkan untuk masalah tertentu. Langkah selanjutnya adalah menganalisis algoritma solusi yang diusulkan tersebut dan menerapkan solusi terbaik yang sesuai.