''' 这个题的考点在.5这个分水岭,而官方给的奇进偶舍这个办法也不能很好的解决这个问题。 那么只能通过逻辑判断来做精度控制判断,把这个问题返抛给解释器去自己判断(其实如何做到16位以上的浮点运算自己没搞明白) 当然,以下方法也有局限性,当小数点后为16个位数时就看最后一个数是9还是小于9(例如:1.499999999999999[9]如果这个数小于9那还能玩,如果大于9就玩不了了,所以这个方法也仅限于16个小数位,超过16位就歇菜了) ''' from math import * n=float(input()) #强制类型转换float def ceilNumber(n): #定义一个函数 """ 假设一个数1.499999 向上取为2 那么2-1.499999>在数学上是大于0.5的,这一点符合数学逻辑,那么说明这个数小数位是大不过0.5的,那必定要向下取,所以就用floor(n). 假设一个数1.500001 ceil(n)向上取则为2,那么2-1.500001必定在数学上是小于0.5的,那么这时候说明他该进位取大值,那就得到ceil(n) 但是问题是,当小数位达到16位后,世界就变了,这个算法就彻底失效了。 """ a=(ceil(n)-n) if (a <=0.5) : print(ceil(n)) else: print(floor(n)) ceilNumber(n)