文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>关于排序(简单)

关于排序(简单)

时间:2010-12-17  来源:虫子混混

  下来我就找啊这个loser tree是啥,翻了翻数据结构和算法的书,不夸张地说我忘的很干净,怎么看怎么书上的东西都很陌生。看了一段时间以过后,本人突发奇想,为什么不封装一个类库呢,不管你是数组还是list<T>,你需要排序?ok,调我的类,我提供给你各种排序方式,只要传进来接回去就排好了,每种排序上面还要标明适用情况,适用数据量。正好自己还能重学一下数据结构和算法,以后用着也方便。

  工作之余跟构架部一个伙计聊天的时候,说了一下这个想法,那哥们很严肃的对我说想法很好,可惜微软已经实现了。让我去看Collections命名空间。

  于是就有了这篇博文,原谅我的无知吧,我真不知道还有SortedList,SortList<TKey,TValue>,SortDictionary<TKey,TValue>。

  简单的做个介绍,具体的msdn上都有

  他们的功能呢,都是把你依次插进去的值排序,插完数据后你再遍历的话,就是排好序的了,key值从小到大。

  他们几个的区别呢

  SortedList在System.Collections,非泛型,内部维护两个数组,foreach遍历的话需要用DictionaryEntry,

foreach (DictionaryEntry de in mySortedList) {...}

  SortList<TKey,TValue>,SortDictionary<TKey,TValue>,泛型,二叉搜索树,foreach遍历的话需要用KeyValuePair <TKey, TValue>。

    SortedList<TKey, TValue>) 使用的内存比 SortedDictionary<TKey, TValue> 少。
SortedDictionary
<TKey, TValue> 可对未排序的数据执行更快的插入和移除操作:它的时间复杂度为 O(log n),而 SortedList<TKey, TValue> 为 O(n)。

 


  下面再上个简单的例子:

代码
public static void RunSnippet()
{
SortedList
<int,String> list=new SortedList<int,String>();
list.Add(
2,"b");
list.Add(
1,"a");
list.Add(
5,"e");

foreach(KeyValuePair<int,String> kv in list)
{
Console.WriteLine(kv.Value);
}
}
显示结果为:
a
b
e
  这个跟我想要的排序库还是有蛮大区别的,不过平时还是可以省很大事的,写下来提醒自己。写的跟水文区别不大,大家别扔鸡蛋!!!

  讲师说解决方案,如有高人能用c#给写一下,小弟将感激不尽!!

相关阅读 更多 +
排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载