首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >排序列表<Rectangle>

排序列表<Rectangle>
EN

Stack Overflow用户
提问于 2012-09-11 05:36:22
回答 4查看 2.5K关注 0票数 1

如何按面积对矩形列表进行排序?我已经在msdn库中查找了IComparable,但无法找到它...我写了以下内容:

代码语言:javascript
运行
复制
SortedL= new List<Rectangle>();
        int count1 = 0;
        int count3 = redovi;
        while (count1 < count3)
        {
            int count2 = 0;
            while (count2 < count3)
            {
                int x = Oblici[count1].Width;
                int y = Oblici[count1].Height;
                int z = Oblici[count2].Width;
                int w = Oblici[count2].Height;
                int area1 = x * y;
                int area2 = z * w;
                int a = area1.CompareTo(area2);
                if (a < 0)
                {
                    count1 = count2;
                    if (count2 < (count3 - 1))
                    {
                        count2++;
                    }
                    else break;
                }
                else if (a == 0)
                {
                    if (count2 < (count3 - 1))
                    {
                        count2++;
                    }
                    else break;
                }
                else if (a > 0)
                {
                    if (count2 < count3 - 1)
                    {
                        count2++;
                    }
                    else break;
                }
            }
            SortedL.Add(Oblici[count1]);
            Oblici.RemoveAt(count1);
            count3 = (count3 - 1);}}

它是有效的,但它相当丑陋,而且我知道有一种更简单的方法...

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2012-09-11 05:43:06

如何,使用lambda表达式创建自己的比较器

代码语言:javascript
运行
复制
mylist.Sort((X, Y) => ((X.Height * X.Width).CompareTo(Y.Height * Y.Width)));
票数 2
EN

Stack Overflow用户

发布于 2012-09-11 05:40:09

假设你可以使用LINQ,这样的东西应该可以工作:

代码语言:javascript
运行
复制
var sortedList = Oblici.OrderBy(r => r.Width * r.Height).ToList();
票数 6
EN

Stack Overflow用户

发布于 2012-09-11 05:53:57

这里是长篇大论的版本,它将帮助您获得其他两个版本。

就像这样

代码语言:javascript
运行
复制
private static int CompareByArea(Rectangle r1, Rectangle r2)
{
   int a1 = r1.Width * r1.Height;
   int a2 = r2.Width * r2.Height;
   if (a1 < a2)
   {
      return - 1;
   }
   else
   {
     if (a1 > a2) 
     {
        return 1; 
     }
   }
   return 0;
}

然后

代码语言:javascript
运行
复制
MyList.Sort(CompareByArea)

List的比较器是一个静态(通常)函数,它以某种方式通过比较两个t返回-1,0,1 (小于、等于或大于

一个有意义的例子明显得让人恼火,不是吗?我也先读了技术术语,听起来很复杂。:(

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12359839

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档