Hide

Problem B
The Gourmet

Languages en sv

The French gourmet Frank is a very well-respected gourmet; his job involves going around to various restaurants, eating their food and then writing a review about the restaurant. But he carries a dark secret: he is actually only interested in eating as much as possible and in any order!

However, Frank understands that a true gourmet can’t eat in just any manner, like starting with his dessert and finishing with a salad. Therefore, he asks for your help in constructing a list with all the different ways he could arrange his courses during a meal, so that he can pick the best order.

During the serving, Frank has M minutes to eat. The restaurant offers N different courses, and he can eat any number of servings of each course. For course i, it takes Ti minutes to eat a serving of it. Frank wants to eat something during each of the M minutes he has, and he wants to finish every course that he is served. He never wants to start eating a new course until he finished the last one.

Your task is to write a program to compute the number of ways he could arrange his meal, given these restrictions.

Input

The first line contains an integer M (1M1000), the number of minutes.

The second line contains an integer N (1N30), the number of courses.

Afterwards, N lines follow with an integer Ti (1Ti200) on each line, the time it takes to eat every dish.

Output

The program should output the number of ways in which Frank can eat during exactly M minutes.

The answer will always be at most 2 billion (2000000000).

Scoring

Your solution will be tested on a set of test case groups. To get the points for a group, you need to pass all the test cases in the group.

Group

Points

Constraints

1

60

The answer will be less than 2 million (2000000).

2

40

No additional constraints

Scoring

Your program will be tested on 5 test cases. For each test cases you pass, you will get 20 points.

For test cases worth 60 points, the answer will be less than 2 million (2000000).

Explanation of Sample 1

Frank is going to eat during 10 minutes and have two courses to choose from, for example a salad (takes 3 minutes to eat) and pie (7 minutes). There are only two ways he can eat them: first pie and then salad or vice versa. If he only eats salad he will either finish too quickly (3 servings=9 minutes) or too late (4 servings=12 minutes).

Sample Input 1 Sample Output 1
10
2
7
3
2
Sample Input 2 Sample Output 2
12
6
1
3
3
5
6
12
498
Hide

Please log in to submit a solution to this problem

Log in