快速排序类
usingSystem;
usingSystem.Data;
usingSystem.Configuration;
usingSystem.Web;
usingSystem.Web.Security;
usingSystem.Web.UI;
usingSystem.Web.UI.WebControls;
usingSystem.Web.UI.WebControls.WebParts;
usingSystem.Web.UI.HtmlControls;
usingSystem.IO;
///<summary>
///快速排序算法
///</summary>
publicclassMyQuickSort
{
publicMyQuickSort()
{
//
//TODO:Addconstructorlogichere
//
}
///<summary>
///快速排序算法
///</summary>
///快速排序为不稳定排序,时间复杂度O(nlog2n),为同数量级中最快的排序方法
///<paramname="arr">划分的数组</param>
///<paramname="low">数组低端上标</param>
///<paramname="high">数组高端下标</param>
///<returns></returns>
staticintPartition(FileInfo[]arr,intlow,inthigh)
{
//进行一趟快速排序,返回中心轴记录位置
//arr[0]=arr[low];
FileInfopivot=arr[low];//把中心轴置于arr[0]
while(low<high)
{
while(low<high&&arr[high].CreationTime<=pivot.CreationTime)
--high;
//将比中心轴记录小的移到低端
Swap(refarr[high],refarr[low]);
while(low<high&&arr[low].CreationTime>=pivot.CreationTime)
++low;
Swap(refarr[high],refarr[low]);
//将比中心轴记录大的移到高端
}
arr[low]=pivot;//中心轴移到正确位置
returnlow;//返回中心轴位置
}
staticvoidSwap(refFileInfoi,refFileInfoj)
{
FileInfot;
t=i;
i=j;
j=t;
}
///<summary>
///快速排序算法
///</summary>
///快速排序为不稳定排序,时间复杂度O(nlog2n),为同数量级中最快的排序方法
///<paramname="arr">划分的数组</param>
///<paramname="low">数组低端上标</param>
///<paramname="high">数组高端下标</param>
publicstaticvoidQuickSort(FileInfo[]arr,intlow,inthigh)
{
if(low<=high-1)//当arr[low,high]为空或只一个记录无需排序
{
intpivot=Partition(arr,low,high);
QuickSort(arr,low,pivot-1);
QuickSort(arr,pivot+1,high);
}
}
}
如使用其它排序算法请参考:http://www.yaosansi.com/blog/article.asp?id=980
使用方法:
System.IO.DirectoryInfodir=newDirectoryInfo(currentFolder);
System.IO.FileInfo[]files=dir.GetFiles();
MyQuickSort.QuickSort(files,0,files.Length-1);//按时间排序
使用后:
如果files的长度大于0,那么files[0]为创建时间最新的文件.