/// <summary> /// 通过[BuffID]二分快速查表 /// </summary> /// <param name="dwBuffID">BuffID</param> /// <returns></returns> public static IEnumerable <BuffUpgradeDataBase> Query(this List <BuffUpgradeDataBase> sorted, ushort dwBuffID) { var key = new BuffUpgradeDataBase() { dwBuffID = dwBuffID }; var comparer = new Comparer1(); var from = sorted.BinarySearch(key, comparer); if (from < 0) { yield break; } var to = from + 1; while (from > 0 && comparer.Compare(key, sorted[from - 1]) == 0) { from--; } while (to < sorted.Count && comparer.Compare(key, sorted[to]) == 0) { to++; } for (var i = from; i < to; i++) { yield return(sorted[i]); } }
/// <summary> /// 通过[BuffID + 等级]二分快速查表 /// </summary> /// <param name="dwBuffID">BuffID</param> /// <param name="dwLevel">等级</param> /// <returns></returns> public static BuffUpgradeDataBase Query(this List <BuffUpgradeDataBase> sorted, ushort dwBuffID, ushort dwLevel) { var key = new BuffUpgradeDataBase() { dwBuffID = dwBuffID, dwLevel = dwLevel }; var comparer = new Comparer2(); var index = sorted.BinarySearch(key, comparer); return(index >= 0 ? sorted[index] : default(BuffUpgradeDataBase)); }