重集合中找出最相近的一个数字

1.网友提供代码

复制代码
 1         private static decimal getNear(List<decimal> num, decimal target)
 2         {
 3             List<decimal> c = new List<decimal>();
 4             foreach (var item in num)
 5             {
 6                 c.Add(Math.Abs(item - target));
 7             }
 8             c.Sort();
 9             for (int i = 0; i < num.Count; i++)
10             {
11                 if (Math.Abs(num[i] - target) == c[0])
12                 {
13                     return num[i];
14                 }
15             }
16             return 0;
17         }
复制代码

2.改进后的代码

1         private static decimal GetNear(List<decimal> collection, decimal target)
2         {
3             return collection.FirstOrDefault(item => Math.Abs(item - target) == collection.Select(s => Math.Abs(s - target)).OrderBy(o => o).First());
4         }

 

posted @   刘小吉  阅读(322)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
点击右上角即可分享
微信分享提示