mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-09-05 23:41:41 +08:00
update
This commit is contained in:
66
leetcode/problem/maximum-number-of-alloys.html
Normal file
66
leetcode/problem/maximum-number-of-alloys.html
Normal file
@@ -0,0 +1,66 @@
|
||||
<p>You are the owner of a company that creates alloys using various types of metals. There are <code>n</code> different types of metals available, and you have access to <code>k</code> machines that can be used to create alloys. Each machine requires a specific amount of each metal type to create an alloy.</p>
|
||||
|
||||
<p>For the <code>i<sup>th</sup></code> machine to create an alloy, it needs <code>composition[i][j]</code> units of metal of type <code>j</code>. Initially, you have <code>stock[i]</code> units of metal type <code>i</code>, and purchasing one unit of metal type <code>i</code> costs <code>cost[i]</code> coins.</p>
|
||||
|
||||
<p>Given integers <code>n</code>, <code>k</code>, <code>budget</code>, a <strong>1-indexed</strong> 2D array <code>composition</code>, and <strong>1-indexed</strong> arrays <code>stock</code> and <code>cost</code>, your goal is to <strong>maximize</strong> the number of alloys the company can create while staying within the budget of <code>budget</code> coins.</p>
|
||||
|
||||
<p><strong>All alloys must be created with the same machine.</strong></p>
|
||||
|
||||
<p>Return <em>the maximum number of alloys that the company can create</em>.</p>
|
||||
|
||||
<p> </p>
|
||||
<p><strong class="example">Example 1:</strong></p>
|
||||
|
||||
<pre>
|
||||
<strong>Input:</strong> n = 3, k = 2, budget = 15, composition = [[1,1,1],[1,1,10]], stock = [0,0,0], cost = [1,2,3]
|
||||
<strong>Output:</strong> 2
|
||||
<strong>Explanation:</strong> It is optimal to use the 1<sup>st</sup> machine to create alloys.
|
||||
To create 2 alloys we need to buy the:
|
||||
- 2 units of metal of the 1<sup>st</sup> type.
|
||||
- 2 units of metal of the 2<sup>nd</sup> type.
|
||||
- 2 units of metal of the 3<sup>rd</sup> type.
|
||||
In total, we need 2 * 1 + 2 * 2 + 2 * 3 = 12 coins, which is smaller than or equal to budget = 15.
|
||||
Notice that we have 0 units of metal of each type and we have to buy all the required units of metal.
|
||||
It can be proven that we can create at most 2 alloys.
|
||||
</pre>
|
||||
|
||||
<p><strong class="example">Example 2:</strong></p>
|
||||
|
||||
<pre>
|
||||
<strong>Input:</strong> n = 3, k = 2, budget = 15, composition = [[1,1,1],[1,1,10]], stock = [0,0,100], cost = [1,2,3]
|
||||
<strong>Output:</strong> 5
|
||||
<strong>Explanation:</strong> It is optimal to use the 2<sup>nd</sup> machine to create alloys.
|
||||
To create 5 alloys we need to buy:
|
||||
- 5 units of metal of the 1<sup>st</sup> type.
|
||||
- 5 units of metal of the 2<sup>nd</sup> type.
|
||||
- 0 units of metal of the 3<sup>rd</sup> type.
|
||||
In total, we need 5 * 1 + 5 * 2 + 0 * 3 = 15 coins, which is smaller than or equal to budget = 15.
|
||||
It can be proven that we can create at most 5 alloys.
|
||||
</pre>
|
||||
|
||||
<p><strong class="example">Example 3:</strong></p>
|
||||
|
||||
<pre>
|
||||
<strong>Input:</strong> n = 2, k = 3, budget = 10, composition = [[2,1],[1,2],[1,1]], stock = [1,1], cost = [5,5]
|
||||
<strong>Output:</strong> 2
|
||||
<strong>Explanation:</strong> It is optimal to use the 3<sup>rd</sup> machine to create alloys.
|
||||
To create 2 alloys we need to buy the:
|
||||
- 1 unit of metal of the 1<sup>st</sup> type.
|
||||
- 1 unit of metal of the 2<sup>nd</sup> type.
|
||||
In total, we need 1 * 5 + 1 * 5 = 10 coins, which is smaller than or equal to budget = 10.
|
||||
It can be proven that we can create at most 2 alloys.
|
||||
</pre>
|
||||
|
||||
<p> </p>
|
||||
<p><strong>Constraints:</strong></p>
|
||||
|
||||
<ul>
|
||||
<li><code>1 <= n, k <= 100</code></li>
|
||||
<li><code>0 <= budget <= 10<sup>8</sup></code></li>
|
||||
<li><code>composition.length == k</code></li>
|
||||
<li><code>composition[i].length == n</code></li>
|
||||
<li><code>1 <= composition[i][j] <= 100</code></li>
|
||||
<li><code>stock.length == cost.length == n</code></li>
|
||||
<li><code>0 <= stock[i] <= 10<sup>8</sup></code></li>
|
||||
<li><code>1 <= cost[i] <= 100</code></li>
|
||||
</ul>
|
Reference in New Issue
Block a user