mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 23:08:57 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			46 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>You are given an undirected graph defined by an integer <code>n</code>, the number of nodes, and a 2D integer array <code>edges</code>, the edges in the graph, where <code>edges[i] = [u<sub>i</sub>, v<sub>i</sub>]</code> indicates that there is an <strong>undirected</strong> edge between <code>u<sub>i</sub></code> and <code>v<sub>i</sub></code>. You are also given an integer array <code>queries</code>.</p>
 | |
| 
 | |
| <p>Let <code>incident(a, b)</code> be defined as the <strong>number of edges</strong> that are connected to <strong>either</strong> node <code>a</code> or <code>b</code>.</p>
 | |
| 
 | |
| <p>The answer to the <code>j<sup>th</sup></code> query is the <strong>number of pairs</strong> of nodes <code>(a, b)</code> that satisfy <strong>both</strong> of the following conditions:</p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>a < b</code></li>
 | |
| 	<li><code>incident(a, b) > queries[j]</code></li>
 | |
| </ul>
 | |
| 
 | |
| <p>Return <em>an array </em><code>answers</code><em> such that </em><code>answers.length == queries.length</code><em> and </em><code>answers[j]</code><em> is the answer of the </em><code>j<sup>th</sup></code><em> query</em>.</p>
 | |
| 
 | |
| <p>Note that there can be <strong>multiple edges</strong> between the same two nodes.</p>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Example 1:</strong></p>
 | |
| <img alt="" src="https://assets.leetcode.com/uploads/2021/06/08/winword_2021-06-08_00-58-39.png" style="width: 529px; height: 305px;" />
 | |
| <pre>
 | |
| <strong>Input:</strong> n = 4, edges = [[1,2],[2,4],[1,3],[2,3],[2,1]], queries = [2,3]
 | |
| <strong>Output:</strong> [6,5]
 | |
| <strong>Explanation:</strong> The calculations for incident(a, b) are shown in the table above.
 | |
| The answers for each of the queries are as follows:
 | |
| - answers[0] = 6. All the pairs have an incident(a, b) value greater than 2.
 | |
| - answers[1] = 5. All the pairs except (3, 4) have an incident(a, b) value greater than 3.
 | |
| </pre>
 | |
| 
 | |
| <p><strong>Example 2:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> n = 5, edges = [[1,5],[1,5],[3,4],[2,5],[1,3],[5,1],[2,3],[2,5]], queries = [1,2,3,4,5]
 | |
| <strong>Output:</strong> [10,10,9,8,6]
 | |
| </pre>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Constraints:</strong></p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>2 <= n <= 2 * 10<sup>4</sup></code></li>
 | |
| 	<li><code>1 <= edges.length <= 10<sup>5</sup></code></li>
 | |
| 	<li><code>1 <= u<sub>i</sub>, v<sub>i</sub> <= n</code></li>
 | |
| 	<li><code>u<sub>i </sub>!= v<sub>i</sub></code></li>
 | |
| 	<li><code>1 <= queries.length <= 20</code></li>
 | |
| 	<li><code>0 <= queries[j] < edges.length</code></li>
 | |
| </ul>
 |