题解 | #字符串变形#
字符串变形
https://www.nowcoder.com/practice/c3120c1c1bc44ad986259c0cf0f0b80e
import java.util.*;
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param s string字符串
* @param n int整型
* @return string字符串
*/
public String trans (String s, int n) {
// write code here
List<String> res = new ArrayList<>();
for(int i=0; i<n; ){
char ch = s.charAt(i);
StringBuilder sb = new StringBuilder();
if(Character.isLetter(ch)){
sb = new StringBuilder();
while(i < n && Character.isLetter(s.charAt(i))){
sb.append(charReverse(s.charAt(i)));
i++;
}
}
if(!Character.isLetter(ch)){
sb = new StringBuilder();
while(i < n && !Character.isLetter(s.charAt(i))){
sb.append(charReverse(s.charAt(i)));
i++;
}
}
res.add(sb.toString());
}
StringBuilder strSb = new StringBuilder();
for(int i=res.size()-1; i>=0; i--){
strSb.append(res.get(i));
}
return strSb.toString();
}
char charReverse(char ch){
if('a' <= ch && ch <= 'z'){
return (char)(ch-32);
}
if('A' <= ch && ch <= 'Z'){
return (char)(ch+32);
}
return ch;
}
}

