首页 > 编程语言 >c#集合去重&排序常用方法

c#集合去重&排序常用方法

时间:2023-08-07 20:31:49浏览次数:52  
标签:Name HashSet c# Price Drink 集合 new 排序 drinks


 list与数组转Hashset&SortedSet

//创建hashset去重
var hashSet = new HashSet<int>(){1,1,2,2};
Console.WriteLine("HashSet:"+String.Join(", ", hashSet));
// HashSet:1, 2

//创建list包含重复元素
var ints = new List<int>{1,1,3,3,2,2};
//创建数组转HashSe包含重复元素
int[] numbers = { 1, 1, 3, 2, 2 };


//list转HashSet
var set = ints.ToHashSet();
Console.WriteLine("List转HashSet:"+String.Join(", ", set));
//List转HashSet:1, 3, 2

var immutableSortedSet = ints.ToImmutableSortedSet();
Console.WriteLine("immutableSortedSet:"+String.Join(", ", immutableSortedSet));


//数组转HashSet
var hashSet1 = new HashSet<int>(numbers);
Console.WriteLine("数组转HashSet:"+String.Join(", ", hashSet1));
//数组转HashSet:1, 3, 2

//数组转SortedSet
var sortedSet = new SortedSet<int>(numbers);
Console.WriteLine("数组转SortedSet:"+String.Join(", ", sortedSet));
//数组转SortedSet:1, 2, 3

c#集合去重&排序常用方法_重复元素

当hashset存的是类时

创建饮料类

public class Drink
{
    public String Name { get; set; }
    
    public int Price { get; set; }
}

new一个HashSet存放饮料类 

var drinks = new HashSet<Drink>();
drinks.Add(new Drink{Name = "牛奶",Price = 19});
drinks.Add(new Drink{Name = "牛奶",Price = 20});
drinks.Add(new Drink{Name = "茉莉花茶",Price = 19});
drinks.Add(new Drink{Name = "茉莉花茶",Price = 19});
foreach (var drink in drinks)
{
    Console.WriteLine(drink.Name+drink.Price);
}

c#集合去重&排序常用方法_重复元素_02

 打印出来并未去重

自定义比较规则

public class DrinkEquelityCompare : IEqualityComparer<Drink>
{
    public bool Equals(Drink x, Drink y)
    {
        //Name相等去除
        return x.Name == y.Name;
    }

    public int GetHashCode(Drink obj)
    {
        return base.GetHashCode();
    }
}

重新new一个类

//var drinks = new HashSet<Drink>(new DrinkEquelityCompare());
drinks.Add(new Drink{Name = "牛奶",Price = 19});
drinks.Add(new Drink{Name = "牛奶",Price = 20});
drinks.Add(new Drink{Name = "茉莉花茶",Price = 19});
drinks.Add(new Drink{Name = "茉莉花茶",Price = 19});
foreach (var drink in drinks)
{
    Console.WriteLine(drink.Name+drink.Price);
}

此时打印以及去除掉Name相同的值了

c#集合去重&排序常用方法_List_03

 SortedSet存放类时自定义排序规则

 还是用刚刚的Drink类

public class DrinkCompare : IComparer<Drink>
{
    public int Compare(Drink x, Drink y)
    {
        //返回值>0 x大;  返回值=0,一样大;  返回值小于0,y大
        return x.Price-y.Price;
    }
}

添加数据

SortedSet<Drink> sorted = new(new DrinkCompare());
sorted.Add(new Drink{Name = "橘汁",Price = 19});
sorted.Add(new Drink{Name = "牛奶",Price = 20});
sorted.Add(new Drink{Name = "茉莉花茶",Price = 17});
sorted.Add(new Drink{Name = "可乐",Price = 21});

foreach (var drink in sorted)
{
    Console.WriteLine(drink.Name+drink.Price);
}

打印出来的数据以及按照price进行排序了 

c#集合去重&排序常用方法_重复元素_04

标签:Name,HashSet,c#,Price,Drink,集合,new,排序,drinks
From: https://blog.51cto.com/u_16179624/6997665

相关文章

  • 【WCH蓝牙系列芯片】-基于CH582开发板按键控制LED灯
    ---------------------------------------------------------------------------------------------------------------------------------------本文主要介绍CH582的GPIO的基础外设的使用,并且利用GPIO外设点亮LED灯和按键扫描功能。将两者结合,实现按键控制LED灯的状态。<控制LED......
  • CSP-J/S第一轮初赛 ~持续更新~
    CSP-J/S初赛2022更新的初赛知识汇总基础算法链表插入删除数据,操作数据O(1),遍历是O(n),可以进行动态调整。指针指向的是上下节点,链表储存数据下一个节点上一个节点。动态调整:插入一定量的节点,进行调整。插入节点:考虑信息覆盖(这些信息后面是否会再被用到)。寻找和读取比较慢......
  • ceph-deploy部署ceph集群 nautilus 14.2.22
    规划主机名IP地址系统ceph版本ceph硬盘大小组件规划master192.168.1.60CentOS7.9ceph-15.2.10sdb100GOSD、MOD、MDS、MGR主节点node01192.168.1.70CentOS7.9ceph-15.2.10sdb100GOSD从节点node02192.168.1.80CentOS7.9ceph-15.2.10sdb100......
  • Ajax技术、MTV和MVC的概念
    一、Ajax技术1、AJAX(AsynchronousJavascriptAndXML)翻译成中文就是“异步Javascript和XML”。即使用Javascript语言与服务器进行异步交互,传输的数据为XML(当然,传输的数据不只是XML,现在更多使用json数据)。局部刷新、一步提交2、作用前端技术,把前端的数据提交到后端的。Ajax......
  • QSurface
    QSurface#include<QSurface> PublicTypesenumSurfaceClass {Window,Offscreen}enumSurfaceType {RasterSurface,OpenGLSurface,RasterGLSurface,OpenVGSurface,VulkanSurface}PublicFunctionsvirtual~QSurface()virtualQSur......
  • Windows c++检测笔记本是否处于睡眠状态
    最近遇到一个问题,程序需要检测电脑是否处于睡眠状态。一开始使用的方式是在WindowProc里监听WM_POWERBROADCAST消息,对PBT_APMSUSPEND``PBT_APMRESUMEAUTOMATIC消息做处理。但是实际测试中发现,这种方法在台式机中运行良好,但是放到笔记本电脑里就不行,系统休眠时监听不到WM_POWERBRO......
  • webstorm无法启动、重装后无法启动(mac)
    #删除配置信息目录rm-rf~/Library/Preferences/WebStorm*#删除插件信息目录rm-rf~/Library/Application\Support/WebStorm*#缓存信息目录rm-rf~/Library/Caches/WebStorm*#删除日志信息目录rm-rf~/Library/Logs/WebStorm*#删除Webstorm.vmoptions......
  • CF671D Roads in Yusland 题解
    题目链接题目要求我们求出选出若干条路径并最小化花费,如果这是在链上,我们可以考虑直接枚举每条路径的右端点dp,那树呢?把路径剖分整个覆盖的集合就不一定连续了,没法dp,况且题目里给了很强的条件:路径一定是从孩子到祖先,硬转链用不上这个性质,貌似不太对。上述思考启发我们利用树的......
  • 【Azure K8S | AKS】在不丢失文件/不影响POD运行的情况下增加PVC的大小
    问题描述在前两篇文章中,创建了Disk+PV+PVC+POD方案后,并且进入POD中增加文件。【AzureK8S|AKS】在AKS集群中创建PVC(PersistentVolumeClaim)和PV(PersistentVolume)示例【AzureK8S|AKS】进入AKS的POD中查看文件,例如PVCVolumeMounts使用情况但是,当预定的文件夹已经被......
  • Codeforces Round 890 (Div. 2) supported by Constructor Institute A-E1
    An=50非常小所以直接暴力枚举枚举每次把某个数以下的全部减完然后看一下是否上升就行 https://codeforces.com/contest/1856/submission/217275334  B题直接贪心前面优先放最小的最后一个放最大的 然后如果重复了就到前面去看能不能调整一下 https://codeforces.......