Mercado Libre Coupon Challenge
Solution for Mercado Libre's Java + AWS Challenge
Problem and Solution
The purpose of the code in this repo, is to provide the optimal coupon given a list of products and a maximum amount. For example, if we have this list of items:
{
"item_ids": ["MLA1120809452", "MLA816019440", "MLA3", "MLA4", "MLA5"],
"amount": 166352.03
}
we should respond with:
{
"item_ids": ["MLA1120809452", "MLA816019440"],
"amount": 166352.03
}
So, our problem is analog to the 0-1 Knapsack Problem, with the peculiarity that weight and value are the same. In this implementation, the API will:
- Ask the MELI items API whether the items exists, and its price.
- Create a set of unique items, that will be evaluated against the maximum amount.
- Cast the 2 digit floating point prices into long integers - so the price will be viewed in terms of cents.
- Run the Dynamic Programming algorithm that will determine the maximum amount to spend, and determine the items that compose the optimal solution.
- Recast the amount to floating point.
- Return the list of items.
Requirements
This solution requires Java 11. If you want to run the solution by yourself, you have to download the jar file located on the packages section of the repo, and in your local instance, run:
java -jar meli-coupon-challenge.jar
Usage
I have mounted the jar file in ElasticBeanstalk. To run the solution, you need to curl to the endpoint. For example:
curl -o result.txt \
--header "Content-Type: application/json" \
--request POST \
--data '{"item_ids": ["MLA1120809452", "MLA816019440", "MLA3", "MLA4", "MLA5"], "amount": 166352.03}' \
http://melichallenge-env.eba-wx55xpus.us-east-1.elasticbeanstalk.com:8080/coupon
If you are running the API locally, you can try the following queries:
# Testing all-invalid items
curl --header "Content-Type: application/json" \
--request POST \
--data '{"item_ids": ["MLA1", "MLA2", "MLA3", "MLA4", "MLA5"], "amount": 500}' \
http://localhost:8080/coupon
# Testing all-but-one-invalid items, none accepted
curl --header "Content-Type: application/json" \
--request POST \
--data '{"item_ids": ["MLA1120809452", "MLA2", "MLA3", "MLA4", "MLA5"], "amount": 500}' \
http://localhost:8080/coupon
# Testing with two valid items, no accepted items
curl --header "Content-Type: application/json" \
--request POST \
--data '{"item_ids": ["MLA1120809452", "MLA816019440", "MLA3", "MLA4", "MLA5"], "amount": 500}' \
http://localhost:8080/coupon
# Testing with two valid items, first item accepted
curl --header "Content-Type: application/json" \
--request POST \
--data '{"item_ids": ["MLA1120809452", "MLA816019440", "MLA3", "MLA4", "MLA5"], "amount": 60000}' \
http://localhost:8080/coupon
# Testing with two valid items, second item accepted
curl --header "Content-Type: application/json" \
--request POST \
--data '{"item_ids": ["MLA1120809452", "MLA816019440", "MLA3", "MLA4", "MLA5"], "amount": 126352.03}' \
http://localhost:8080/coupon
# Testing with two valid items, both accepted
curl --header "Content-Type: application/json" \
--request POST \
--data '{"item_ids": ["MLA1120809452", "MLA816019440", "MLA3", "MLA4", "MLA5"], "amount": 166352.03}' \
http://localhost:8080/coupon