java实现字符串分割
描述
给定一个非空字符串S,其被N个“分隔成N+1的子串,给定正整数K,要求除第一个子串外,其余的子串每K个字符组成新的子串,并用“分隔。
对于新组成的每一个子串,如果它含有的小写字母比大写字母多,则将这个子串的所有大写字母转换为小写字母:反之,如果它含有的大写字母比小写字母多,则将这个子串的所有小写字母转换为大写字母;大小写字母的数是相等时,不做转换。
输入描述
输入为两行,第一行为参数K,第二行为字符串S。
输出描述
输出转换后的字符串。
用例:
输入:12abc-abCABc-4aB@
3
输出:12abc-abc-ABC-4aB-@
输入:12abc-abCABc-4aB@
12
输出:12abc-abCABc4aB@
java实现(开箱即用)
package com.des.data.test;
public class StringSegmentation {
public static void main(String[] args) {
String str1 = "12abc-abCABc-4aB@";
String Str2 = "12abc-abCABc-4aB@";
System.out.println(split(str1, 12));
}
public static String split(String str, int k) {
StringBuffer res = new StringBuffer();
String[] strings = str.split("-");
StringBuffer stb = new StringBuffer();
for (int i = 0; i < strings.length; i++) {
if (i == 0) {
continue;
}
stb.append(strings[i]);
}
res.append(strings[0]).append("-");
String stbz = stb.toString();
int end = 1;
for (int i = 0; i < stbz.length(); i++) {
res.append(stbz.charAt(i));
if (end == k) {
res.append("-");
end = 1;
} else {
end++;
}
}
System.out.println();
String[] strFen = res.toString().split("-");
StringBuffer resN = new StringBuffer();
for (int i = 0; i < strFen.length; i++) {
String sfs = strFen[i];
if (i == 0) {
resN.append(sfs).append("-");
continue;
}
int up = 0;
int low = 0;
for (int j = 0; j < sfs.length(); j++) {
char c = sfs.charAt(j);
if (Character.isUpperCase(c)) {
up++;
}
if (Character.isLowerCase(c)) {
low++;
}
}
if (low > up) {
String sfsn = sfs.toLowerCase();
resN.append(sfsn).append("-");
}
if (up > low) {
String sfsn = sfs.toUpperCase();
resN.append(sfsn).append("-");
}
if (up == low) {
resN.append(sfs).append("-");
}
}
String resStr = resN.toString();
return resStr.substring(0, resStr.length() - 1);
}
}