mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 23:08:57 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			56 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>There are <code>n</code> projects numbered from <code>0</code> to <code>n - 1</code>. You are given an integer array <code>milestones</code> where each <code>milestones[i]</code> denotes the number of milestones the <code>i<sup>th</sup></code> project has.</p>
 | ||
| 
 | ||
| <p>You can work on the projects following these two rules:</p>
 | ||
| 
 | ||
| <ul>
 | ||
| 	<li>Every week, you will finish <strong>exactly one</strong> milestone of <strong>one</strong> project. You <strong>must</strong> work every week.</li>
 | ||
| 	<li>You <strong>cannot</strong> work on two milestones from the same project for two <strong>consecutive</strong> weeks.</li>
 | ||
| </ul>
 | ||
| 
 | ||
| <p>Once all the milestones of all the projects are finished, or if the only milestones that you can work on will cause you to violate the above rules, you will <strong>stop working</strong>. Note that you may not be able to finish every project's milestones due to these constraints.</p>
 | ||
| 
 | ||
| <p>Return <em>the <strong>maximum</strong> number of weeks you would be able to work on the projects without violating the rules mentioned above</em>.</p>
 | ||
| 
 | ||
| <p> </p>
 | ||
| <p><strong>Example 1:</strong></p>
 | ||
| 
 | ||
| <pre>
 | ||
| <strong>Input:</strong> milestones = [1,2,3]
 | ||
| <strong>Output:</strong> 6
 | ||
| <strong>Explanation:</strong> One possible scenario is:
 | ||
| - During the 1<sup>st</sup> week, you will work on a milestone of project 0.
 | ||
| - During the 2<sup>nd</sup> week, you will work on a milestone of project 2.
 | ||
| - During the 3<sup>rd</sup> week, you will work on a milestone of project 1.
 | ||
| - During the 4<sup>th</sup> week, you will work on a milestone of project 2.
 | ||
| - During the 5<sup>th</sup> week, you will work on a milestone of project 1.
 | ||
| - During the 6<sup>th</sup> week, you will work on a milestone of project 2.
 | ||
| The total number of weeks is 6.
 | ||
| </pre>
 | ||
| 
 | ||
| <p><strong>Example 2:</strong></p>
 | ||
| 
 | ||
| <pre>
 | ||
| <strong>Input:</strong> milestones = [5,2,1]
 | ||
| <strong>Output:</strong> 7
 | ||
| <strong>Explanation:</strong> One possible scenario is:
 | ||
| - During the 1<sup>st</sup> week, you will work on a milestone of project 0.
 | ||
| - During the 2<sup>nd</sup> week, you will work on a milestone of project 1.
 | ||
| - During the 3<sup>rd</sup> week, you will work on a milestone of project 0.
 | ||
| - During the 4<sup>th</sup> week, you will work on a milestone of project 1.
 | ||
| - During the 5<sup>th</sup> week, you will work on a milestone of project 0.
 | ||
| - During the 6<sup>th</sup> week, you will work on a milestone of project 2.
 | ||
| - During the 7<sup>th</sup> week, you will work on a milestone of project 0.
 | ||
| The total number of weeks is 7.
 | ||
| Note that you cannot work on the last milestone of project 0 on 8<sup>th</sup> week because it would violate the rules.
 | ||
| Thus, one milestone in project 0 will remain unfinished.
 | ||
| </pre>
 | ||
| 
 | ||
| <p> </p>
 | ||
| <p><strong>Constraints:</strong></p>
 | ||
| 
 | ||
| <ul>
 | ||
| 	<li><code>n == milestones.length</code></li>
 | ||
| 	<li><code>1 <= n <= 10<sup>5</sup></code></li>
 | ||
| 	<li><code>1 <= milestones[i] <= 10<sup>9</sup></code></li>
 | ||
| </ul>
 |