Leetcode-992 Subarrays with K Different Integers(K 个不同整数的子数组)

 1 #define maxn 1000000
 2 #define _for(i,a,b) for(int i = (a);i < (b);i ++)
 3 #define pb push_back
 4 
 5 class Solution
 6 {
 7     public:
 8         vector<int> root;
 9         int _find(int x)
10         {
11             if(root[x]==x)    return x;
12             return root[x] = _find(root[x]);
13         }
14         void merge(int x,int y)
15         {
16             int rx = _find(x);
17             int ry = _find(y);
18             if(rx==ry) return ;
19             root[rx] = ry;
20         }
21         bool equationsPossible(vector<string>& equations)
22         {
23             for(int i = 0;i < 27;i ++)
24                 root.pb(i);
25 
26             for(int i = 0; i < equations.size(); i ++)
27             {
28                 if(equations[i][1]=='=')
29                 {
30                     merge(equations[i][0]-'a',equations[i][3]-'a');
31                 }
32             }
33             for(int i = 0; i < equations.size(); i ++)
34             {
35                 if(equations[i][1]=='!')
36                 {
37                     if(_find(equations[i][0]-'a')==_find(equations[i][3]-'a'))
38                         return false;
39                 }
40             }
41             return true;
42         }
43 };

并查集水过

转载于:https://www.cnblogs.com/Asurudo/p/10359924.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值