Skip to content

Commit e9d0b1f

Browse files
committed
add 1615
1 parent c88a302 commit e9d0b1f

File tree

2 files changed

+53
-0
lines changed

2 files changed

+53
-0
lines changed

README.md

+1
Original file line numberDiff line numberDiff line change
@@ -73,6 +73,7 @@ LeetCode Solution In Hard Way
7373
|1624|[Largest Substring Between Two Equal Characters](https://leetcode.cn/problems/largest-substring-between-two-equal-characters/) | [C++](./src/Problem_1624_maxLengthBetweenEqualCharacters.cc)|Easy|
7474
|1620|[Coordinate With Maximum Network Quality](https://leetcode.cn/problems/coordinate-with-maximum-network-quality/) | [C++](./src/Problem_1620_bestCoordinate.cc)|Medium|
7575
|1619|[Mean of Array After Removing Some Elements](https://leetcode.cn/problems/mean-of-array-after-removing-some-elements/) | [C++](./src/Problem_1619_trimMean.cc)|Easy|
76+
|1615|[Maximal Network Rank](https://leetcode.cn/problems/maximal-network-rank/) | [C++](./src/Problem_1615_maximalNetworkRank.cc)|Medium|
7677
|1604|[Alert Using Same Key-Card Three or More Times in a One Hour Period](https://leetcode.cn/problems/alert-using-same-key-card-three-or-more-times-in-a-one-hour-period/) | [C++](./src/Problem_1604_alertNames.cc)|Medium|
7778
|1592|[Rearrange Spaces Between Words](https://leetcode.cn/problems/rearrange-spaces-between-words/) | [C++](./src/Problem_1592_reorderSpaces.cc)|Easy|
7879
|1590|[Make Sum Divisible by P](https://leetcode.cn/problems/make-sum-divisible-by-p/) | [C++](./src/Problem_1590_minSubarray.cc)|Medium|
+52
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,52 @@
1+
#include <iostream>
2+
#include <iterator>
3+
#include <vector>
4+
5+
#include "UnitTest.h"
6+
7+
using namespace std;
8+
9+
class Solution
10+
{
11+
public:
12+
int maximalNetworkRank(int n, vector<vector<int>> &roads)
13+
{
14+
vector<vector<bool>> connect(n, vector<bool>(n));
15+
vector<int> degree(n);
16+
for (auto &v : roads)
17+
{
18+
connect[v[0]][v[1]] = true;
19+
connect[v[1]][v[0]] = true;
20+
degree[v[0]]++;
21+
degree[v[1]]++;
22+
}
23+
int max = 0;
24+
for (int i = 0; i < n; i++)
25+
{
26+
for (int j = i + 1; j < n; j++)
27+
{
28+
int rank = degree[i] + degree[j] - (connect[i][j] ? 1 : 0);
29+
max = std::max(max, rank);
30+
}
31+
}
32+
return max;
33+
}
34+
};
35+
36+
void testMaximalNetworkRank()
37+
{
38+
Solution s;
39+
vector<vector<int>> n1 = {{0, 1}, {0, 3}, {1, 2}, {1, 3}};
40+
vector<vector<int>> n2 = {{0, 1}, {0, 3}, {1, 2}, {1, 3}, {2, 3}, {2, 4}};
41+
vector<vector<int>> n3 = {{0, 1}, {1, 2}, {2, 3}, {2, 4}, {5, 6}, {5, 7}};
42+
EXPECT_EQ_INT(4, s.maximalNetworkRank(4, n1));
43+
EXPECT_EQ_INT(5, s.maximalNetworkRank(5, n2));
44+
EXPECT_EQ_INT(5, s.maximalNetworkRank(8, n3));
45+
EXPECT_SUMMARY;
46+
}
47+
48+
int main()
49+
{
50+
testMaximalNetworkRank();
51+
return 0;
52+
}

0 commit comments

Comments
 (0)