程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> C# 數組查找與排序實現代碼

C# 數組查找與排序實現代碼

編輯:ASP.NET基礎
1. 查找對象
復制代碼 代碼如下:
Person p1 = new Person( " http://www.my400800.cn " , 18 );
Person p2 = new Person( " http://www.my400800.cn " , 19 );
Person p3 = new Person( " http://www.my400800.cn " , 20 );
Person[] persons = ... { p1, p2, p3 } ;
// 查找p2所在數組中的位置
Array.IndexOf < Person > (persons, p2);

2. 查找值
復制代碼 代碼如下:
Person p1 = new Person( " http://www.my400800.cn " , 18 );
Person p2 = new Person( " http://blog.my400800.cn " , 19 );
Person p3 = new Person( " http:// blog.my400800.cn/400電話 " , 20 );
Person[] persons = ... { p1, p2, p3 } ;
Person p4 = new Person(p2.Name, p2.Age);
// 查找數組中與p4相同的元素所在的位置
Array.IndexOf < Person > (persons, p4);

但是,這種方法必需使Person重載Object的 Equals 比較方法
復制代碼 代碼如下:
public override bool Equals( object obj)
... {
Person person = obj as Person;
if (person == null ) return false ;
return ( this .name == person.name && this .age == person.age);
}

第二種按對象的值查找的方法
實現IComparabler接口
復制代碼 代碼如下:
public int CompareTo( object obj)
... {
Person person = obj as Person;
if (person == null )
throw new Exception( " The method or operation is not implemented. " );
// 先從年齡開始比較
int ageResult = this .age.CompareTo(person.age);
if (ageResult == 0 )
... {
// 如果年齡相等在坐姓名比較
return this .name.CompareTo(person.name);
}
else
... {
return ageResult;
}
}

實現了IComparable接口後就可以使用Array.BinarySearch()進行查找了
復制代碼 代碼如下:
// 得到 person 在 persons 中有相同值的下標
// 如果多個相同的值,BinarySearch將取最後
// 一個有相同值的數組下標
Array.BinarySearch < Person > (persons, person);

注:使用Array.BinarySeach必須操作一個排序好的數組
3. 排序
只要對象實現了IComparable接口,就可以使用Array中靜態的方法Sort進行排序
復制代碼 代碼如下:
// 必需使比較的對象實現IComparable接口
Array.Sort < Person > (persons);

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved