3240.Mashmokh and ACM

Time Limit: 1s Memory Limit: 256MB

Mashmokh's boss, Bimokh, didn't like Mashmokh. So he fired him. Mashmokh decided to go to university and participate in ACM instead of finding a new job. He wants to become a member of Bamokh's team. In order to join he was given some programming tasks and one week to solve them. Mashmokh is not a very experienced programmer. Actually he is not a programmer at all. So he wasn't able to solve them. That's why he asked you to help him with these tasks. One of these tasks is the following.

A sequence of l integers b1,b2,...,bl (1 \le b1 \le b2 \le ... \le bl \le n) is called good if each number divides (without a remainder) by the next number in the sequence. More formally 3240_1.png for all i (1 \le i \le l-1).

Given n and k find the number of good sequences of length k. As the answer can be rather large print it modulo 1000000007 (109+7).

Input Format(From the terminal/stdin)

The first line of input contains two space-separated integers n,k(1 \le n,k \le 2000).

Output Format(To the terminal/stdout)

Output a single integer - the number of good sequences of length k modulo 1000000007 (109+7).

Sample Input 1

Copy
3 2
 · \n

Sample Output 1

Copy
5
 \n

Sample Input 2

Copy
6 4
 · \n

Sample Output 2

Copy
39
  \n

Sample Input 3

Copy
2 1
 · \n

Sample Output 3

Copy
2
 \n

Hints

In the first sample the good sequences are: [1,1],[2,2],[3,3],[1,2],[1,3].

Submit

请先 登录

© 2025 FAQs