把abcd...s共19个字母组成的序列重复拼接106次,得到长度为2014的串。
接下来删除第1个字母(即开头的字母a),以及第3个,第5个等所有奇数位置的字母。
得到的新串再进行删除奇数位置字母的动作。如此下去,最后只剩下一个字母,请写出该字母。
答案是一个小写字母,请通过浏览器提交答案。不要填写任何多余的内容
public static void main(String[] args){
String s="abcdefghijklmnopqrs";
String str="";
for(int i=0;i<106;i++){
str=str+s;
}
//System.out.println(str.length());
boolean[] flag=new boolean[str.length()];
for(int i=0;i<flag.length;i++){
flag[i]=true;//未被删除的字母标记为true
}
int oldIndex=0;//旧串的下标
int newIndex=0;//新串的下标
int leftCount=str.length();//剩余的字母数
while(leftCount>1){//当最后只剩下一个字母
if(flag[oldIndex]==true){//如果该字母未被删除
if(newIndex%2==0){//判断是否要删除
flag[oldIndex]=false;//删除
leftCount--;//剩余字母数-1
}
newIndex++;//未被删除的字母构成新串
}
oldIndex++;//旧串的遍历
if(oldIndex==str.length()){//得到的新串再进行删除奇数位置字母的动作。所以下标都重置为0
newIndex=0;
oldIndex=0;
}
}
for(int i=0;i<flag.length;i++){
if(flag[i]==true){
System.out.println(str.charAt(i));
//return;
}
}
}