Description
data:image/s3,"s3://crabby-images/ecee0/ecee042d8edc280e603de7c23a1632a73f1f9ff2" alt=""
data:image/s3,"s3://crabby-images/66ed1/66ed10e386a6b8b02a7a9c6a3bab7490d08fb6e1" alt=""
Submission
class Solution { public: bool isBipartite(vector<vector<int>>& graph) { int n = graph.size(); vector<int> color(n, -1); queue<int> q; for(int i = 0; i < n; ++i) { q.push(i); if(color[i] != -1) continue; // bicolor: 0 or 1, -1 for not visited yet color[i] = 1; while(!q.empty()) { auto cur = q.front(); q.pop(); for(auto x: graph[cur]) { if(color[x] == -1) { color[x] = 1 - color[cur]; q.push(x); } else if(color[x] == color[cur]) return false; } } } return true; } };
data:image/s3,"s3://crabby-images/aef10/aef106b5d2b0157f4e2228fcae547faa5ffaa297" alt=""
References
data:image/s3,"s3://crabby-images/afd0a/afd0a74f2a752b57fd70f1e7211ffa94ba02f148" alt=""