一个由小写字母组成的字符串可以看成一些同一字母的最大碎片组成的。例如,"aaabbaaac"是由下面碎片组成的:‘aaa’,‘bb’,‘c’。牛牛现在给定一个字符串,请你帮助计算这个字符串的所有碎片的平均长度是多少。
输入描述:
输入包括一个字符串s,字符串s的长度length(1 ≤ length ≤ 50),s只含小写字母('a'-'z')
输出描述:
输出一个整数,表示所有碎片的平均长度,四舍五入保留两位小数。
如样例所示: s = "aaabbaaac"
所有碎片的平均长度 = (3 + 2 + 3 + 1) / 4 = 2.25
输入例子1:
aaabbaaac
输出例子1:
2.25
思路分析:
可将输入的字符串转化为字符串数组,遍历数组找出一共有多少个字符串碎片(字符串的长度是不会变的)然后直接相除就可以得到结果,值得注意的是结果要求四舍五入保留两位小数,这里用了BigDecimal类中的setScale方法。
JAVA代码实现:
import java.math.BigDecimal;
import java.util.Scanner;
import static java.math.RoundingMode.HALF_UP;
public class ZiFuChuanSuiPian {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String s = sc.nextLine();
char[] chars = s.toCharArray();
int x = 1;
for (int i = 1; i
if(chars[i]!=chars[i-1]){
x++;
}
}
double v= (double)s.length()/x;
BigDecimal bd = new BigDecimal(v);
BigDecimal bd1 = bd.setScale(2, HALF_UP);
System.out.println(bd1);
}
}
标签:Java,Scanner,java,碎片,import,字符串,长度,校招
来源: https://blog.csdn.net/weixin_44818889/article/details/100935671