标签:return 找链 2127 int mx2 favorite 员工 mx1 leetcode
1 class Solution { 2 public: 3 int maximumInvitations(vector<int>& favorite) { 4 int n=favorite.size(); 5 vector<int>ind(n); 6 for(int i=0;i<n;i++)ind[favorite[i]]++; 7 vector<int>mxlen(n,1); 8 queue<int>q; 9 for(int i=0;i<n;i++) 10 if(!ind[i])q.push(i); 11 12 while(q.size()) 13 { 14 auto u=q.front(); 15 q.pop(); 16 --ind[favorite[u]]; 17 mxlen[favorite[u]]=max(mxlen[u]+1,mxlen[favorite[u]]); 18 if(!ind[favorite[u]]) q.push(favorite[u]); 19 } 20 int f[n]; 21 memset(f,0,sizeof(f)); 22 function<int(int u)>dfs=[&](int u) 23 { 24 if(f[u])return 0; 25 f[u]=1; 26 int v=favorite[u]; 27 return dfs(v)+1; 28 }; 29 int mx1=0,mx2=0; 30 for(int i=0;i<n;i++) 31 { 32 if(!ind[i]||f[i])continue; 33 int cnt=dfs(i); 34 if(cnt==2)mx2+=mxlen[i]+mxlen[favorite[i]]; 35 else mx1=max(mx1,cnt); 36 } 37 return max(mx1,mx2); 38 } 39 };
学会了用拓扑排序找链,找环。
标签:return,找链,2127,int,mx2,favorite,员工,mx1,leetcode 来源: https://www.cnblogs.com/matt-su/p/15759185.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。