如何解决检查字符串是否至少包含两个字母,并检查字符串是否包含非字母
Java程序,用于从用户那里获取字符串。如果字符串大小是偶数,则反转字符串的第二部分并显示该字符串。如果字符串大小为奇数,则从中间字符反转字符串并显示它。字符串应仅包含字母。否则,显示“不是有效的字符串”。该字符串应至少包含两个字母,否则显示“字符串大小太小”。
package Section6;
import java.util.*;
import java.util.regex.Pattern;
public class Challenge6 {
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
System.out.print("Enter the string: ");
String str = sc.nextLine();
if (str.length() == 0 || str.length() <= 1) {
System.out.print("Size of string " + str + " is too low");
return;
}
else if (str.length() == 2 && str.matches("^[a-zA-Z]*$"))
{
if(Pattern.matches("^[a-zA-Z]*$",str))
{
Reverse_string(str);
}
else
{
System.out.print(str + " is not a valid string");
return;
}
}
else if (str.length() > 2)
{
if(str != null && str.matches("^[a-zA-Z]*$")) {
Reverse(str);
}
}
}
public static void Reverse_string(String s) {
String reverse = "";
int length = s.length();
for (int i = length - 1 ; i >= 0 ; i--)
reverse = reverse + s.charAt(i);
System.out.println(reverse);
}
public static void Reverse(String str) {
int mid = str.length() / 2;
String[] parts = { str.substring(0,mid),str.substring(mid) };
String p2 = parts[0]; // first part
String p1 = parts[1]; // second part
String s1a = str.substring(0,(str.length() / 2));
String s1b = str.substring((str.length() / 2));
System.out.print(p2);
int i = s1b.length();
while (i > 0) {
System.out.print(s1b.charAt(i - 1));
i--;
}
}
}
解决方法
只需进行一些编辑即可获得所需的输出。
正如我的问题所说,我只需要检查字符串长度是否为2,但我不应该反转它。因此从这种情况下删除了反向方法。
并且用于非字母字符检查。我会检查它,但是只需要添加一条打印语句以显示其无效字符串即可。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。