网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
源码和解析
解析:
可以将输入的资源池 转换为数组 例如1,3-5=> [1,3,4,5] 移除目标资源3后再重新合并为 [1,4-5]
示例代码:
import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;
public class T3 {
public static void main(String[] args) {
//输入的VLAN串 20-21,15,18,30,5-10
String input="20-21,15,18,30,5-10";
//要申请的VLAN资源
Integer destVlan=15;
//获得VLAN池
List<Integer> vlanPool=new ArrayList<Integer>();//VLAN池
String[] vlanGroup=input.split(",");
for(int i=0;i<vlanGroup.length;i++){
if(vlanGroup[i].contains("-")){
String vlanItems[]=vlanGroup[i].split("-");
Integer start=Integer.parseInt(vlanItems[0]);
Integer end=Integer.parseInt(vlanItems[1]);
for(int j=start;j<=end;j++){
vlanPool.add(j);
}
continue;
}
vlanPool.add(Integer.parseInt(vlanGroup[i]));
}
//升序排序
vlanPool.sort(new Comparator<Integer>() {
@Override
public int compare(Integer o1, Integer o2) {
if(o1>o2){
return 1;
}
if(o1<o2){
return -1;
}
return 0;
}
});
//移出要移出的那个数
vlanPool.remove(destVlan);//注意目标vlan要保持和List的值相同
String result="";
Integer last=null;//记录追加的最后一个值
for(int index=0;index<vlanPool.size();index++){
if(last==null){
result+=vlanPool.get(index);
last=vlanPool.get(index);
continue;
}
if(vlanPool.get(index)-last==1){
if(result.endsWith("-"+last)){
//已经有一个结束的数字了 那么就替换掉这个
result=result.replace(last+"", vlanPool.get(index)+"");
}else{
result+="-"+vlanPool.get(index);
}
}else{
result+=","+vlanPool.get(index);
}
last=vlanPool.get(index);
}
System.out.println(vlanPool);
System.out.println(result);
}
}
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!