一、输入一个字符串,可以有空格,输出逆序的字符串。
利用Java种的StringBuffer来进行反转
public static void main(String args[]) {
String a ="i am student";
String reverse =new StringBuffer(a).reverse().toString();
System.out.println(a);
System.out.println(reverse);
}
二、反转英语句子
利用数组的倒序读取
将一个英文语句以单词为单位逆序排放。例如“I am a boy”,逆序排放后为“boy a am I”所有单词之间用一个空格隔开,语句中除了英文字母外,不再包含其他字符
public static void main(String args[]) {
String a ="i am a boy";
String arr[] = a.split(" ");
int j =0;
String res[] =new String[arr.length];
for (int i = arr.length -1; i >=0; i--) {
res[j] = arr[i].toString();
j++;
}
for (int k =0; k < res.length; k++) {
System.out.print(res[k]+" ");
}
}
三、空格替换
利用replaceAll()
将字符串中的空格全部替换为“%20”。假定该字符串有足够的空间存放新增的字符,并且知道字符串的真实长度(小于等于1000),同时保证字符串由大小写的英文字母组成。
public static void main(String[] args) {
String initStr ="Mr John Smith";
String res = initStr.replaceAll(" ", "%20");
System.out.println(res);
}
四、删除公共字符
利用replaceAll()
从第一字符串中删除第二个字符串中所有的字符。例如,输入”They are students.”和”aeiou”,则删除之后的第一个字符串变成”Thy r stdnts.”
public static void main(String[] args) {
String initStr1 ="They are students";
String initStr2 ="aeiou";
String result ="";
char charArr1[] = initStr1.toCharArray();
char charArr2[] = initStr2.toCharArray();
for (int i =0; i < charArr1.length; i++) {
for (int j =0; j < charArr2.length; j++) {
if (charArr1[i] == charArr2[j]) {
initStr1 = initStr1.replaceAll(String.valueOf(charArr1[i]), "");
}
}
}
System.out.println(initStr1);
}
五、字符串的旋转
用substring()
对于一个字符串,和字符串中的某一位置,请设计一个算法,将包括i位置在内的左侧部分移动到右边,将右侧部分移动到左边。
给定字符串A和它的长度n以及特定位置p,请返回旋转后的结果。
public static void main(String[] args) {
String initString ="ABCDEFGH";
String result =fanZhuan(initString, 4);
System.out.println(result);
}
public static StringfanZhuan(String initString, int index) {
String result ="";
String resString1 = initString.substring(0, index +1);
String resString2 = initString.substring(index +1, initString.length());
result = resString2 + resString1;
return result;
}
六、输入一个字符串,求出该字符串包含的字符集合
例如
输入 abcqweracb
输出 abcqwer
考察不重复集合的使用
public static void main(String[] args) {
String initString ="abcqweracb";
char initStringArr[] = initString.toCharArray();
Set set =new LinkedHashSet<>(); //按照添加的顺序
// Set set = new TreeSet<>(); //按照英语字母的顺序
for (int i =0; i < initStringArr.length; i++) {
set.add(String.valueOf(initStringArr[i]));
}
set.forEach(e -> System.out.print(e));
}
七、字符串变形
首先这个字符串中包含着一些空格,就像"Hello World"一样,然后我们要做的是把着个字符串中由空格隔开的单词反序,同时反转每个字符的大小写。比如"Hello World"变形后就变成了"wORLD hELLO"。
public static void main(String[] args) {
StringBuilder initString =new StringBuilder("This is a sample");
char initStringArr[] = initString.toString().toCharArray();
for (int i =0; i < initStringArr.length; i++) {
if (initStringArr[i] >='A' && initStringArr[i] <='Z') {
initString.setCharAt(i, initStringArr[i] +=32);
}else if (initStringArr[i] >='a' && initStringArr[i] <='z') {
initString.setCharAt(i, initStringArr[i] -=32);
}else {
initString.setCharAt(i,'%'); //StringBuilder 无法操作空格,所以将空格转成%
}
}
String initStringSArr[] = initString.toString().split("%");
for (int j = initStringSArr.length; j >0; j--) {
System.out.print(initStringSArr[j -1]+" ");
}
}
八、找出给定字符串中大写字符(即'A'-'Z')的个数
public static void main(String[] args) {
String initString ="add123AD#$%#%#O";
int num =0;
char initStringCArr[] = initString.toCharArray();
for (char c : initStringCArr) {
if (c >='A' && c <='Z') {
num++;
}
}
System.out.println(num);
}
查找输入整数二进制中1的个数
输入5,5的二进制为101,输出2
public static void main(String[] args) {
int a =145;
int count =0;
String one1 =countOne(a);
// countOne2(a);
// countOne3(a);
while (one1.indexOf('1') != -1) {
one1 = one1.substring(one1.indexOf('1') +1, one1.length());
count++;
}
System.out.println(count);
}
//递归循环
public static StringcountOne(int number) {
StringBuffer buffer =new StringBuffer("");
while (number !=0) {
buffer.append(number %2);
number = number /2;
}
System.out.println(buffer.toString());
return buffer.toString();
}
//移位
public static void countOne2(int number) {
for (int i =31; i >=0; i--) {
System.out.println(number >>> i &1);
}
}
// 直接使用Integer的toBinaryString方法
public static void countOne3(int number) {
String result = Integer.toBinaryString(number);
System.out.println(result);
}
在字符串中找出连续最长的数字串
输入 abcd12345ed125ss123456789
输出 123456789
找出字符串中第一个只出现一次的字符
输出第一个只出现一次的字符,如果不存在输出-1
public static void main(String[] args) {
String initStr ="asdfasdfoopp";
String res ="-1";
char initStrArr[] = initStr.toCharArray();
for (int i =0; i < initStrArr.length; i++) {
if (initStr.indexOf(initStrArr[i]) == initStr.lastIndexOf(initStrArr[i])) {
res = String.valueOf(initStrArr[i]);
}
}
System.out.println(res);
}