မိတ္ေဆြ၊ ညီအစ္ကို၊ ေမာင္ႏွမမ်ားအားလံုး မဂၤလာပါဗ်ာ။ ဒီေန႔ေတာ့ က်ေနာ္တို႔ VS C# ကို အသံုးျပဳၿပီး Sorting Algorithms ေတြထဲက တစ္ခုျဖစ္တဲ့ Bubble Sort အေၾကာင္းေလးကို ေလ့လာၾကည့္ၾကပါ့မရ္ဗ်။
အေပၚကပံုကေတာ့ Bubble Sort Algorithm အလုပ္ လုပ္သြားတဲ့ ပံုစံပဲျဖစ္ပါတရ္။ အေပၚပံုမွာျမင္ရတဲ့အတိုင္း ကိန္းစဥ္တန္း ငါးလံုးရွိရင္ Loop Step ငါးခုရွိမွာျဖစ္ပါတရ္။ Step တစ္ခုစီတိုင္းမွာ ကပ္လွ်ပ္ ကိန္းစဥ္တန္းႏွစ္လံုးကို ႏႈိင္းယွဥ္ၿပီး ငယ္စဥ္ႀကီးလိုက္အတြက္ ေနာက္ကိန္းကငယ္ေနလွ်င္ေရွ႕ကိန္းနဲ႔ေနရာခ်ိန္းပါတရ္။ ေနာက္ကိန္းကႀကီးေနရင္ေတာ့ ဒီအတိုင္းပဲ ျပန္စီပါတရ္ဗ်။ ဒီနည္းအတုိင္းပဲ ကိန္းစဥ္တန္းဆံုးတဲ့အထိ ကပ္လွ်ပ္ႏွစ္လံုးစီ ႏႈိင္းယွဥ္ၿပီး ေနရာအခ်ိန္းအေျပာင္းလုပ္ပါတရ္။ Step တစ္ခုဆံုးတဲ့အခ်ိန္မွာ ကိန္းစဥ္တန္းရဲ႕ ေနာက္ဆံုးကို ေရာက္သြားတဲ့ ကိန္းဟာ အႀကီးဆံုးကိန္း ျဖစ္ေနမွာပါ။ ဒါေၾကာင့္ Step 1 ၿပီးတဲ့အခ်ိန္မွာ ေနာက္ဆံုး ကိန္းဟာ အႀကီးဆံုးကိန္း၊ Step 2 ဆံုးတဲ့အခါ ေနာက္ဆံုး ကိန္းႏွစ္လံုးဟာ Sort လုပ္ၿပီးသား အႀကီးဆံုးကိန္းျဖစ္ေနမွာပါ။ ဒီနည္းအတိုင္း ကိန္းစဥ္တန္းအားလံုး Sort လုပ္ၿပီးသည္အထိ Step သြားၿပီး Loop လုပ္ ႏႈိင္းယွဥ္ပါတရ္ဗ်ာ။ အေပၚက ပံုကို ၾကည့္လုိက္ရင္ေတာ့ က်ေနာ္ ဘာကို ဆိုလိုေနတရ္ဆုိတာကို နားလည္ႏိုင္ၾက လိမ့္မရ္လို႔ ထင္ပါတရ္။
ဒါကေတာ့ က်ေနာ္ရဲ႕ ေလ့လာၾကည့္မဲ့ Bubble Sort အတြက္ GUI ပါ။ DataGridView ထဲကို Array Set လုပ္တာကိုေတာ့ ေရွ႕က Insertion Sort သင္ခန္းစာမွာ ရွင္းျပခဲ့ၿပီးျဖစ္လို႔ မရွင္းေတာ့ပါဘူးဗ်ာ။ private void txtSetColumn_TextChanged(object sender, EventArgs e){ ...} မွာ Coding ေလး ၾကည့္လိုက္ပါ။
ေနာက္တစ္ခုကေတာ့ Bubble Sort ကို က်ေနာ္ Method ခြဲေရးထားတဲ့ ပံုစံပါ။ public int[] BubbleSorted(int[] arr, string Opt){...} မွာ Coding ေလး ေလ့လာၾကည့္ပါအံုးဗ်။
Method ကို Calling လုပ္တဲ့ ပံုစံကိုေတာ့ private void btnBubbleSort_Click(object sender, EventArgs e) {...} မွာေ လ့လာႏိုင္ပါတရ္။
Result ပံုေလးနဲ႔ Bubble Sort ရဲ႕ အလုပ္ လုပ္ပံုေလးကို သိၿပီဆိုရင္ေတာ့ က်ေနာ္တို႔ ပိုၿပီး နားလည္သြားေအာင္ ေအာက္မွာ Coding အျပည့္အစံုေလးကို ေလ့လာၾကည့္ၾကမရ္ဗ်ာ။
နားလည္ႏိုင္ၾကလိမ့္မရ္လို႔ ေမ်ာ္လင့္ပါတရ္ဗ်။ မိတ္ေဆြ၊ ညီအစ္ကို၊ ေမာင္ႏွမအားလံုး ေလ့လာျခင္းျဖင့္ ေက်နပ္ႏိုင္ၾကပါေစ။
using System;
using System.Windows.Forms;
namespace BubbleSort
{
public partial class frmBubbleSort : Form
{
public frmBubbleSort()
{
InitializeComponent();
}
private void txtSetColumn_TextChanged(object sender, EventArgs e)
{
if (txtSetColumn.Text != "") {
//For Row of UnSorted-DataGridView
dgvUnSort.RowTemplate.Height = 35;
dgvUnSort.RowCount = 1;
dgvUnSort.RowHeadersVisible = false;
//For Column of UnSorted-DataGridView
dgvUnSort.ColumnCount = int.Parse(txtSetColumn.Text);
dgvUnSort.AllowUserToResizeColumns = true;
dgvUnSort.ColumnHeadersVisible = false;
for (int i = 0; i < dgvUnSort.ColumnCount; i++) {
dgvUnSort.Columns[i].Width = 35;
}
//For Row of Sorted-DataGridView
dgvSort.RowTemplate.Height = 35;
dgvSort.RowCount = 1;
dgvSort.RowHeadersVisible = false;
//For Column of Sorted-DataGridView
dgvSort.ColumnCount = int.Parse(txtSetColumn.Text);
dgvSort.AllowUserToResizeColumns = true;
dgvSort.ColumnHeadersVisible = false;
for (int i = 0; i < dgvSort.ColumnCount; i++) {
dgvSort.Columns[i].Width = 35;
}
} else {
dgvUnSort.Rows.Clear();
dgvSort.Rows.Clear();
}
}
private void btnBubbleSort_Click(object sender, EventArgs e)
{
//Set Default Sorting Option
if (cbSortOption.SelectedIndex == -1) {
cbSortOption.Text = "ASC";
}
//Load Data to Array[] from DataDridView
int length = dgvUnSort.ColumnCount;
int[] UnSortedArr = new int[length];
for (int i = 0; i < length; i++) {
UnSortedArr[i] = int.Parse(dgvUnSort.Rows[0].Cells[i].Value.ToString());
}
//Call BubbleSort Method
int[] SortedResult = BubbleSorted(UnSortedArr, cbSortOption.Text);
//Add Sorted Data to DataGridView
for (int i = 0; i < SortedResult.Length; i++) {
dgvSort.Rows[0].Cells[i].Value = SortedResult[i];
}
}
public int[] BubbleSorted(int[] arr, string Opt)
{
int length = arr.Length;
switch (Opt)
{
case "ASC" :
for (int i = 0; i < length; i++) {
for (int j = 0; j < length-1 - i ; j++) {
if (arr[j] > arr[j+1]) {
int key = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = key;
}
}
}
return arr;
case "DESC":
for (int i = 0; i < length; i++) {
for (int j = 0; j < length - 1 - i; j++) {
if (arr[j] < arr[j + 1]) {
int key = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = key;
}
}
}
return arr;
default:
return null;
}
}
}
}
Labels:
Sorting Algorithms

0 Responses so far.
Post a Comment