C# —— Sort排序

Array.Sort(ints);// 默认的排序方式 正序排序

cs 复制代码
int[] ints = { 1, 2, 3, 89, 20, 100 };
Console.Write(string.Join(",", ints));

参数1 是排序的数组,参数2 是函数 函数的两个参数 是数组的两个元素,

当返回x-y 正序排序

cs 复制代码
Array.Sort(ints, (x, y) => x - y);// 正序排序
Console.Write(string.Join(",", ints));

当返回y-x 正序排序

cs 复制代码
Array.Sort(ints, (x, y) => y - x);// 倒序排序
Console.WriteLine(string.Join(",", ints));

数组的元素是字符串 字符串也可以进行比较

因为字符串不能使用x-y这种方式进行比较

使用 CaseInsensitiveComparer.Default.Compare 对数字 字符串 汉字都可以进行对比

return CaseInsensitiveComparer.Default.Compare(x, y); // 正序排序

cs 复制代码
string[] strings = { "ad", "啊", "d", "ac", "9", "1", "中" };
Array.Sort(strings, (x, y) =>
{
    return CaseInsensitiveComparer.Default.Compare(y, x);// 倒序排序
});
Console.WriteLine(string.Join(",", strings));

实例:

cs 复制代码
string[] pukes = { "大王", "3", "8", "10", "J", "小王", "2" };

string[] leve1 = { "大王", "小王", "2", "A", "K", "Q", "J", "10", "9", "8", "7", "6", "5", "4", "3" };

Array.Sort(pukes, (x, y) =>
{
    // 将x和y转换对应的数字level数组的数字
    int levex = Array.IndexOf(leve1, x);// 获取原数组x 在leve1数组的索引值
    int levay = Array.IndexOf(leve1, y);// 获取y在leve1数组的索引值

    return levex - levay;
});

Console.WriteLine(string.Join(",", pukes));
相关推荐
MQLYES37 分钟前
03-BTC-数据结构
数据结构·算法·哈希算法
无限进步_1 小时前
【数据结构&C语言】对称二叉树的递归之美:镜像世界的探索
c语言·开发语言·数据结构·c++·算法·github·visual studio
不会c嘎嘎1 小时前
C++ 进阶:从理论到手撕 Unordered 系列容器(哈希表)
数据结构·哈希算法·散列表
nice_lcj5202 小时前
数据结构之堆:从概念到应用全解析(附TOP-K经典问题)
java·数据结构·算法
故事不长丨2 小时前
C#进制转换:从基础原理到实战应用
开发语言·c#·进制转换·16进制·2进制·10进制
漫随流水2 小时前
leetcode算法(429.N叉树的层序遍历)
数据结构·算法·leetcode·二叉树
liulilittle2 小时前
VEthernet 框架实现 tun2socks 的技术原理
网络·windows·c#·信息与通信·通信
漫随流水2 小时前
leetcode算法(116.填充每个节点的下一个右侧节点指针)
数据结构·算法·leetcode·二叉树
云草桑3 小时前
.net AI API应用 客户发的信息提取对接上下游系统报价
ai·c#·.net·semantickernel·sk
橘颂TA3 小时前
【剑斩OFFER】算法的暴力美学——力扣 844 题:比较含退格的字符串
数据结构·c++·算法·力扣·结构与算法