မိတ္ေဆြ၊ ညီအစ္ကို၊ ေမာင္ႏွမမ်ားအားလံုး မဂၤလာပါဗ်ာ။ က်ေနာ္တို႔ ဒီေန႔ေတာ့ VS C# ကို အသံုးျပဳၿပီး Sorting Algorithms ေတြထဲက တစ္ခုျဖစ္တဲ့ Insertion Sort အေၾကာင္းေလးကို Coding ေလးေရးၿပီး ေလ့လာၾကည့္ၾကပါမရ္။
အေပၚက ပံုကေတာ့ Insertion Sort အလုပ္ လုပ္သြားတဲ့ ပံုစံပါ။ က်ေနာ့္ Website ေလးျဖစ္တဲ့ programmingknowledge.blogspot.com မွာ Insertion Sort အေၾကာင္းကို သီအုိရီနဲ႔ႏြယ္ၿပီး အနည္းငရ္ ရွင္းျပခဲ့ၿပီးပါၿပီ။ မိတ္ေဆြတို႔ ေလ့လာႏိုင္ပါတရ္ဗ်။ ဒါေၾကာင့္ ဒီေန႔ ေလ့က်င့္ခန္းမွာ က်ေနာ္ အေသးစိတ္မရွင္းေတာ့ပဲ Code Flow ေလးနဲ႔ Screen Shoot ေလးေတြပဲ ျပပါ့မရ္ဗ်။
Coding Flow ကိုေတာ့ ေလ့လာၾကည့္မရ္ဆိုရင္ေတာ့ အဆင့္(၄)ဆင့္နဲ႔ ေတြ႔ရမွာပါ။
အဆင့္(၁)။ မိမိႏွစ္သက္ရာ Columns အေရအတြက္ကို သက္မွတ္ၿပီး DataGridView မွာ Array[ ] အတြက္ Table တစ္ခု တည္ေဆာက္ယူမွာျဖစ္ပါတရ္။
အဆင့္(၂)။ ဖန္တီးထားေသာ UnSorted Table မွာ မိမိႏွစ္သက္ရာ Array[ ] အတြက္ ကိန္းစဥ္တန္းတစ္ခုကို ရိုက္ထည့္ပါ့မရ္။
အဆင့္(၃)။ ဒီအဆင့္မွာေတာ့ Sorting Option ကို ေရြးခ်ယ္ၿပီး Insertion Sort Btn ကိုႏွိပ္ကာ Sorting လုပ္ေဆာင္ယူမွာျဖစ္ပါတရ္။
အဆင့္(၄)။ ဒါဆိုရင္ေတာ့ က်ေနာ္တို႔ ေျပာင္းလဲယူလိုက္တဲ့ Sorting လုပ္ၿပီးသား Array[] တစ္ခုကို Sorted DataGridView မွာျမင္ရမွာျဖစ္ပါတရ္ဗ်ာ။
ဒီေလ့က်င့္ခန္းမွာ Sorting ကို သီးသန္႔ Method ခြဲၿပီး ေရးထားပါတရ္။ ဒီမွာ မိတ္ေဆြတို႔ တစ္ခု သတိထားရမွာေတာ့ က်ေနာ္တို႔ ဖန္တီးထားတဲ့ Sorting Method က Array[] ကို Parameter Passing လုပ္ထားၿပီး Array[] ကိုပဲ return ျပန္ထားတဲ့အတြက္ေၾကာင့္ Sorting Method ကို ေခၚမသံုးခင္ မိမိ Sort လုပ္ခ်င္ေသာ ကိန္းစဥ္တန္းကို Array[] တစ္ခုအျဖစ္ အရင္ ဖန္တီးယူရမွာျဖစ္ပါတရ္ဗ်။
public int[] InsertSort(int[] arr, string Opt){ ... }
ဒါက Insertion Sort ရဲ႕ Method ပါ။
int[] SortedArr = InsertSort(Array, "ASC/DESC");
ဒါကေတာ့ Calling ပံုစံပါ။
Coding အျပည့္အစံုေလးကို ေအာက္မွာ ၾကည့္လိုက္ပါအံုးဗ်ာ။
နားလည္ႏိုင္ၾကလိမ့္မရ္လို႔ ေမ်ာ္လင့္ပါတရ္ဗ်။
မိတ္ေဆြ၊ ညီအစ္ကို၊ ေမာင္ႏွမအားလံုး ေလ့လာျခင္းျဖင့္ ေက်နပ္ႏိုင္ၾကပါေစ။
using System; using System.Windows.Forms; namespace InsertionSort { public partial class frmInsertionSort : Form { public frmInsertionSort() { 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 btnInsertionSort_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 InsertionSort Method int[] SortedResult = InsertSort(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[] InsertSort(int[] arr, string Opt) { int key, j; switch (Opt) { case "ASC" : for (int i = 1; i < arr.Length; i++){ key = arr[i]; j = i - 1; while (key < arr[j] && j >= 0){ arr[j+1] = arr[j]; j = j-1; if (j < 0) break; } arr[j+1] = key; } return arr; case "DESC" : for (int i = 1; i < arr.Length; i++){ key = arr[i]; j = i - 1; while (key > arr[j] && j <= arr.Length) { arr[j+1] = arr[j]; j = j-1; if (j < 0) break; } arr[j+1] = key; } return arr; default : return null; } } } }
Labels:
Sorting Algorithms
0 Responses so far.
Post a Comment