代码拉取完成,页面将自动刷新
class UnionUtil{
Map<Integer, Integer> eleLeaderMap = new HashMap<>();
int unionCount = 0;
public int getUnionCount(){
return unionCount;
}
public void addIfNotExist(Integer ele){
if(!eleLeaderMap.containsKey(ele)){
eleLeaderMap.put(ele, ele);
unionCount++;
}
}
public Integer getLeader(Integer ele){
if(ele != null){
Integer leader = eleLeaderMap.get(ele);
if(ele.equals(leader)){
return ele;
}
else{
Integer finalLeader = getLeader(leader);
eleLeaderMap.put(ele, finalLeader);
return finalLeader;
}
}
return null;
}
public boolean union(Integer eleA, Integer eleB){
addIfNotExist(eleA);
addIfNotExist(eleB);
Integer eleALeader = getLeader(eleA), eleBLeader = getLeader(eleB);
if(!eleALeader.equals(eleBLeader)){
eleLeaderMap.put(eleALeader, eleBLeader);
unionCount--;
return true;
}
return false;
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。