1.将一句话中的单词倒置,标点符号不变。Java实现方式,在网上看到一道这样的题目,例如输入 i can fly. 输出fly. can i 于是自己实现了一下,感觉倒也不难哦
List<String>list=new ArrayList<>();
String s="i can fly.";
String [] arr = s.split("\\s+");
for(String ss : arr){
list.add(ss);
}
String aa="";
for (int i = list.size()-1; i >=0 ; i--) {
aa=aa+list.get(i).toString()+" ";
}
System.out.println("---"+aa);
2.为了得到一个数的"相反数",我们将这个数的数字顺序颠倒,然后再加上原先的数得到"相反数"。例如,为了得到1325的"相反数",首先我们将该数的数字顺序颠倒,我们得到5231,之后再加上原先的数,我们得到5231+1325=6556.如果颠倒之后的数字有前缀零,前缀零将会被忽略。例如n = 100, 颠倒之后是1,感觉倒也不难哦
int s=1234;
String bb=reverse(String.valueOf(s));
int w=Integer.valueOf(bb);
System.out.println("shuzi----"+(s+w));
3.字符串碎片问题,例如“aaabbaaac”是由下面碎片组成“aaa”,“bb”,“c”,则计算所有碎片的平均长度,例如输入为一个字符串,输出为一个整数,表示所有碎片的平均长度,四舍五入保留两位小数。例如:string=“aaabbaaac”。所有碎片的平均长度=(3+2+3+1)/4.感觉倒也不难哦
String string="aaabbaaacddd";
char s=string.charAt(0);
double count=1,d;
for (int i = 0; i < string.length(); i++) {
if (s!=string.charAt(i)) {
s=string.charAt(i);//切换碎片块
count++;//碎片长度数加1
}
}
d=string.length()/count;
System.out.println(String.format("%.2f", d));
4.输入两个字符串,从第一字符串中删除第二个字符串中所有的字符。例如,输入”They are students.”和”aeiou”,则删除之后的第一个字符串变成”Thy r stdnts.”。感觉倒也不难哦
String a="abcdefg";
String b="abfg";
for ( int i = 0; i < b.length (); i++ )
{
for ( int j = 0; j < a.length (); j++ )
{
if (a.charAt (j) == b.charAt (i))
{
a=a.replace(String.valueOf(a.charAt(j)),"");
}
}
}
System.out.println("ss----"+a);