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--;
}
}
}
答案 0 :(得分:0)
只需进行一些编辑即可获得所需的输出。
正如我的问题所说,我只需要检查字符串长度是否为2,但我不应该反转它。因此从这种情况下删除了反向方法。
并且用于非字母字符检查。我会检查它,但是只需要添加一条打印语句以显示其无效字符串即可。