mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-11-04 11:43:12 +08:00 
			
		
		
		
	update
This commit is contained in:
		@@ -0,0 +1,164 @@
 | 
			
		||||
<p>You are given an integer array <code>nums</code> of length <code>n</code>.</p>
 | 
			
		||||
 | 
			
		||||
<p>For every <strong>positive</strong> integer <code>g</code>, we define the <strong>beauty</strong> of <code>g</code> as the <strong>product</strong> of <code>g</code> and the number of <strong>strictly increasing</strong> <strong><span data-keyword="subsequence-array-nonempty">subsequences</span></strong> of <code>nums</code> whose greatest common divisor (GCD) is exactly <code>g</code>.</p>
 | 
			
		||||
 | 
			
		||||
<p>Return the <strong>sum</strong> of <strong>beauty</strong> values for all positive integers <code>g</code>.</p>
 | 
			
		||||
 | 
			
		||||
<p>Since the answer could be very large, return it modulo <code>10<sup>9</sup> + 7</code>.</p>
 | 
			
		||||
 | 
			
		||||
<p> </p>
 | 
			
		||||
<p><strong class="example">Example 1:</strong></p>
 | 
			
		||||
 | 
			
		||||
<div class="example-block">
 | 
			
		||||
<p><strong>Input:</strong> <span class="example-io">nums = [1,2,3]</span></p>
 | 
			
		||||
 | 
			
		||||
<p><strong>Output:</strong> <span class="example-io">10</span></p>
 | 
			
		||||
 | 
			
		||||
<p><strong>Explanation:</strong></p>
 | 
			
		||||
 | 
			
		||||
<p>All strictly increasing subsequences and their GCDs are:</p>
 | 
			
		||||
 | 
			
		||||
<table style="border: 1px solid black;">
 | 
			
		||||
	<thead>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<th style="border: 1px solid black;">Subsequence</th>
 | 
			
		||||
			<th style="border: 1px solid black;">GCD</th>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</thead>
 | 
			
		||||
	<tbody>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">[1]</td>
 | 
			
		||||
			<td style="border: 1px solid black;">1</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">[2]</td>
 | 
			
		||||
			<td style="border: 1px solid black;">2</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">[3]</td>
 | 
			
		||||
			<td style="border: 1px solid black;">3</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">[1,2]</td>
 | 
			
		||||
			<td style="border: 1px solid black;">1</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">[1,3]</td>
 | 
			
		||||
			<td style="border: 1px solid black;">1</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">[2,3]</td>
 | 
			
		||||
			<td style="border: 1px solid black;">1</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">[1,2,3]</td>
 | 
			
		||||
			<td style="border: 1px solid black;">1</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</tbody>
 | 
			
		||||
</table>
 | 
			
		||||
 | 
			
		||||
<p>Calculating beauty for each GCD:</p>
 | 
			
		||||
 | 
			
		||||
<table style="border: 1px solid black;">
 | 
			
		||||
	<thead>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<th style="border: 1px solid black;">GCD</th>
 | 
			
		||||
			<th style="border: 1px solid black;">Count of subsequences</th>
 | 
			
		||||
			<th style="border: 1px solid black;">Beauty (GCD × Count)</th>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</thead>
 | 
			
		||||
	<tbody>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">1</td>
 | 
			
		||||
			<td style="border: 1px solid black;">5</td>
 | 
			
		||||
			<td style="border: 1px solid black;">1 × 5 = 5</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">2</td>
 | 
			
		||||
			<td style="border: 1px solid black;">1</td>
 | 
			
		||||
			<td style="border: 1px solid black;">2 × 1 = 2</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">3</td>
 | 
			
		||||
			<td style="border: 1px solid black;">1</td>
 | 
			
		||||
			<td style="border: 1px solid black;">3 × 1 = 3</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</tbody>
 | 
			
		||||
</table>
 | 
			
		||||
 | 
			
		||||
<p>Total beauty is <code>5 + 2 + 3 = 10</code>.</p>
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<p><strong class="example">Example 2:</strong></p>
 | 
			
		||||
 | 
			
		||||
<div class="example-block">
 | 
			
		||||
<p><strong>Input:</strong> <span class="example-io">nums = [4,6]</span></p>
 | 
			
		||||
 | 
			
		||||
<p><strong>Output:</strong> <span class="example-io">12</span></p>
 | 
			
		||||
 | 
			
		||||
<p><strong>Explanation:</strong></p>
 | 
			
		||||
 | 
			
		||||
<p>All strictly increasing subsequences and their GCDs are:</p>
 | 
			
		||||
 | 
			
		||||
<table style="border: 1px solid black;">
 | 
			
		||||
	<thead>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<th style="border: 1px solid black;">Subsequence</th>
 | 
			
		||||
			<th style="border: 1px solid black;">GCD</th>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</thead>
 | 
			
		||||
	<tbody>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">[4]</td>
 | 
			
		||||
			<td style="border: 1px solid black;">4</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">[6]</td>
 | 
			
		||||
			<td style="border: 1px solid black;">6</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">[4,6]</td>
 | 
			
		||||
			<td style="border: 1px solid black;">2</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</tbody>
 | 
			
		||||
</table>
 | 
			
		||||
 | 
			
		||||
<p>Calculating beauty for each GCD:</p>
 | 
			
		||||
 | 
			
		||||
<table style="border: 1px solid black;">
 | 
			
		||||
	<thead>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<th style="border: 1px solid black;">GCD</th>
 | 
			
		||||
			<th style="border: 1px solid black;">Count of subsequences</th>
 | 
			
		||||
			<th style="border: 1px solid black;">Beauty (GCD × Count)</th>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</thead>
 | 
			
		||||
	<tbody>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">2</td>
 | 
			
		||||
			<td style="border: 1px solid black;">1</td>
 | 
			
		||||
			<td style="border: 1px solid black;">2 × 1 = 2</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">4</td>
 | 
			
		||||
			<td style="border: 1px solid black;">1</td>
 | 
			
		||||
			<td style="border: 1px solid black;">4 × 1 = 4</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td style="border: 1px solid black;">6</td>
 | 
			
		||||
			<td style="border: 1px solid black;">1</td>
 | 
			
		||||
			<td style="border: 1px solid black;">6 × 1 = 6</td>
 | 
			
		||||
		</tr>
 | 
			
		||||
	</tbody>
 | 
			
		||||
</table>
 | 
			
		||||
 | 
			
		||||
<p>Total beauty is <code>2 + 4 + 6 = 12</code>.</p>
 | 
			
		||||
</div>
 | 
			
		||||
 | 
			
		||||
<p> </p>
 | 
			
		||||
<p><strong>Constraints:</strong></p>
 | 
			
		||||
 | 
			
		||||
<ul>
 | 
			
		||||
	<li><code>1 <= n == nums.length <= 10<sup>4</sup></code></li>
 | 
			
		||||
	<li><code>1 <= nums[i] <= 7 * 10<sup>4</sup></code></li>
 | 
			
		||||
</ul>
 | 
			
		||||
		Reference in New Issue
	
	Block a user