查找最近的班次算法

一天有N个班次  (1<=N<=8)

假设为3个班次 比如 日期 2009-6-12

班次1 2009-6-12  8:30- 2009-6-12 11:30

班次2 2009-6-12  13:30-2009-6-12 17:30

班次3 2009-6-12 19:00-2009-6-12 21:00

传入一个时间点,必须是2009-6-12 内的

有无简便的算法  可以快速判断与这个时间点 最近的班次

比如:

2009-6-12  8:20 那么对应的班次是 班次1

2009-6-12 16:30 对应的班次是 班次2

2009-6-12 18:51:14 对应的班次是 班次3


慕田峪7331174
浏览 528回答 2
2回答

至尊宝的传说

如果你是要将数据读取出来再比对的话,可以分别将三个班次的时间的.Ticks属性减去传入时间的.Ticks属性,比较得出结果的绝对值,绝对值最小的就是最邻近的班次。如果你需要在数据库内直接比对,那建议改一下数据表结构,为其增加一个长整型字段,存入班次时间的.Ticks属性,然后再进行比对。注:.Ticks属性是DateTime对象所拥有的
打开App,查看更多内容
随时随地看视频慕课网APP