No tag edit access

E. Maxim and Calculator

time limit per test

4 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputMaxim has got a calculator. The calculator has two integer cells. Initially, the first cell contains number 1, and the second cell contains number 0. In one move you can perform one of the following operations:

- Let's assume that at the current time the first cell contains number
*a*, and the second cell contains number*b*. Write to the second cell number*b*+ 1; - Let's assume that at the current time the first cell contains number
*a*, and the second cell contains number*b*. Write to the first cell number*a*·*b*.

Maxim is wondering, how many integers *x* (*l* ≤ *x* ≤ *r*) are there, such that we can write the number *x* to the first cell of the calculator, having performed at most *p* moves.

Input

The first line contains three integers: *l*, *r*, *p* (2 ≤ *l* ≤ *r* ≤ 10^{9}, 1 ≤ *p* ≤ 100).

The numbers in the line are separated by single spaces.

Output

In a single line print a single integer — the answer to the problem.

Examples

Input

2 10 3

Output

1

Input

2 111 100

Output

106

Input

2 111 11

Output

47

Codeforces (c) Copyright 2010-2017 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Aug/21/2017 18:49:07 (c3).

Desktop version, switch to mobile version.

User lists

Name |
---|