'''
这个题的考点在.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)