蓝桥杯java试题及答案Word下载.docx
《蓝桥杯java试题及答案Word下载.docx》由会员分享,可在线阅读,更多相关《蓝桥杯java试题及答案Word下载.docx(17页珍藏版)》请在冰豆网上搜索。
![蓝桥杯java试题及答案Word下载.docx](https://file1.bdocx.com/fileroot1/2022-11/16/c9379f84-2edb-468f-88e7-2880603eea2f/c9379f84-2edb-468f-88e7-2880603eea2f1.gif)
if(sourse.size()==0){
for(inti=0;
iresult.size();
i++){
system.out.print(result.elementat(i));
}
system.out.print(\n);
count++;
return;
isourse.size();
vectorcharactertsourse=newvectorcharacter(sourse);
vectorcharactertresult=newvectorcharacter(result);
tresult.add(sourse.elementat(i));
tsourse.remove(i);
newquestion1().fullpermutation(tsourse,tresult);
publicstaticvoidmain(string[]args){
scannerscanner=newscanner(system.in);
intn=scanner.nextint();
vectorcharactersourse=newvectorcharacter();
vectorcharacterresult=newvectorcharacter();
in;
sourse.add((char)(a+i));
newquestion1().fullpermutation(sourse,result);
system.out.println(question1.count);
*/
方法二:
importjava.util.arraylist;
importjava.util.iterator;
importjava.util.linkedhashset;
importjava.util.list;
importjava.util.scanner;
importjava.util.set;
publicclassdemo03{
//去掉重复元素,放入lis
publicstaticvoidremoveduplicate(strings,setcharacterlis){
for(charx:
s.tochararray()){
lis.add(x);
//为方便操作将sets转lis
publicstaticvoidconvert(listcharacterlis,setcharactersets){
iteratorcharacteriter=sets.iterator();
while(iter.hasnext()){
lis.add(iter.next());
//检测符合条件的元素组合
publicstaticvoidcheck(setcharactersets){
listcharacterlis=newarraylistcharacter();
convert(lis,sets);
stringbuffersb=newstringbuffer();
for(inti=0;
ilis.size()-2;
i++){
for(intj=i+1;
j+1lis.size();
j++){//向后添加两位,所以j+1lis.size()
for(intk=j+1;
klis.size();
k++){
sb.append(lis.get(i));
sb.append(lis.get(j));
sb.append(lis.get(k));
system.out.println(sb);
//输出组合
sb.setlength(0);
//清空
publicstaticvoidmain(string[]args){
scannerscan=newscanner(system.in);
system.out.println(输入串(不大于30个字符)。
);
strings=scan.nextline();
setcharactersets=newlinkedhashsetcharacter();
removeduplicate(s,sets);
check(sets);
运行结果:
输入串(不大于30个字符)。
abcd
abc
abd
acd
bcd
2.串的简单处理
串的处理
在实际的开发工作中,对字符串的处理是最常见的编程任务。
本题目即是要求程序对用户输入的串进行处理。
具体规则如下:
1.把每个单词的首字母变为大写。
2.把数字与字母之间用下划线字符(_)分开,使得更清晰
3.把单词中间有多个空格的调整为1个空格。
例如:
用户输入:
youandmewhatcpp2005program
则程序输出:
youandmewhatcpp_2005_program
thisisa99cat
thisisa99_cat
我们假设:
用户输入的串中只有小写字母,空格和数字,不含其它的字母或符号。
每个单词间由1个或多个空格分隔。
假设用户输入的串长度不超过200个字符。
publicclassquestion2{
stringstring=scanner.nextline();
vectorcharactervector=newvectorcharacter();
istring.length();
vector.add(string.charat(i));
try{
intindex=0;
while(indexvector.size()){
if(index==0vector.elementat(index)=avector.elementat(index)=z){
vector.set(index,(char)(vector.elementat(index)-(a-a)));
}elseif(vector.elementat(index-1)==vector.elementat(index)==){
vector.remove(index);
index--;
}elseif(vector.elementat(index-1)==(vector.elementat(index)=avector.elementat(index)=z)){
}else
if((vector.elementat(index)=avector.elementat(index)=z)(vector.elementat(index-1)=0vector.elementat(index-1)=9)){
vector.add(index,_);
index++;
if((vector.elementat(index-1)=avector.elementat(index-1)=z)(vector.elementat(index)=0vector.elementat(index)=9)){
ivector.size();
system.out.print(vector.elementat(i));
system.out.println();
}catch(arrayindexoutofboundsexceptione){
//todo:
handleexception
importjava.util.regex.matcher;
importjava.util.regex.pattern;
/*
*本题目即是要求程序对用户输入的串进行处理。
*1.把每个单词的首字母变为大写。
*2.把数字与字母之间用下划线字符(_)分开,使得更清晰
*3.把单词中间有多个空格的调整为1个空格。
*我们假设:
每个单词间由1个或多个空格分隔。
*假设用户输入的串长度不超过200个字符。
publicclasssimplestring{
publicstaticvoidmain(stringargs[]){
stringstr=;
str=(newscanner(system.in)).nextline();
string[]str1=str.split([]+);
istr1.length;
i++)str1[i]=string.valueof((char)(str1[i].charat(0)+(a-a)))+str1[i].substring
(1);
strings=;
istr1.length-1;
i++)//system.out.print(str1[i]+);
{
s+=str1[i]+;
s+=str1[str1.leng