本次更新了几个处理字符串的小Demo,希望同学们能更好的巩固之前的基础知识
题目1:给定一个由数字组成的字符串,如:“1239586838923173478943890234092”,统计出每个数字出现的次数
//4.给定一个由数字组成的字符串,如:"1239586838923173478943890234092",统计出每个数字出现的次数
public static void strCount(String str) {
char[] chr = str.toCharArray();
for (int i = 0; i <= 9; i++) {
int count = 0;
for (int j = 0; j < chr.length; j++) {
if(i == chr[j]-48) {//数字0-9ascii码是48-57
count++; //每一轮判断一个数字并统计次数
}
}
System.out.println(i+"出现的次数是"+count+"次");
}
}
题目2:给定一个长度,随机产生一个该长度的字符串,由大写组成
//3.给定一个长度,随机产生一个该长度的字符串,由大写组成
public static String bigString(int len) {
Random rom = new Random(); //生成一个随机数
char[] cstr = new char[len]; //用一个char数组存储
for (int i = 0; i < cstr.length; i++) {
int a = rom.nextInt(25)+65;//0-25 加65就是65-90也就是A-Z
cstr[i]= (char)a; //每次赋值给char数组
}
String string =String.valueOf(cstr); //char数组转为字符串
return string;//返回字符串
}
题目3:给定一个字符串,判断该字符串中是否包含某个子串.如果包含,求出子串的所有出现位置.
如:"abcbcbabcb34bcbd"中,"bcb"子串的出现位置为: 1,7,12.字符串和子串均由用户输入
/*
* 2.给定一个字符串,判断该字符串中是否包含某个子串.如果包含,求出子串的所有出现位置.
如:"abcbcbabcb34bcbd"中,"bcb"子串的出现位置为: 1,7,12.字符串和子串均由用户输入
*/
public static void site(String str1 , String str2) {
int count = 0;//定义一个变量来控制索引位置
while (true) {
int index = str1.indexOf(str2, count);//每次返回索引位置,
if (index < 0) {//控制循环结束
break;
}
System.out.println("有,出现位置为"+index);//打印每次索引位置
count = str2.length()+index;//查到的索引位置加上索引字符长度赋值给控制索引的变量
}
}
题目4:设计一个方法,两个参数(double ,int) 第一个参数是用于四舍五入,
int确定保留几位小数点,确定是否四舍五入
//1.设计一个方法,两个参数(double ,int) 第一个参数是用于四舍五入,
//int确定保留几位小数点,确定是否四舍五入
public static void rounding(double a, int b) {
// 方式一
BigDecimal bg = new BigDecimal(a);
double f1 = bg.setScale(b, BigDecimal.ROUND_HALF_UP).doubleValue();
System.out.println(f1);
// 方式二
System.out.println(String.format("%." + b + "f", a));
}
希望这些练习对你今后的学习更有帮助!