在Java中比较包含一组数字的两个字符串,而不管它们的顺序如何



我需要比较Java中的两组数字。为了测试程序,两个集合将是相同的(123),除了一个集合将有不同顺序的"123"。我目前输入"123"作为中奖号码,输入"321"作为播放号码,使用.contains()方法将两者作为Strings进行比较。

我的代码如下:

    if (playNum.contains(winNum))
        System.out.println("True") ;
    else
        System.out.println("False") ;

我试图让程序识别出"123"的任何变体都是赢家。任何帮助都将不胜感激。

请查看我的解决方案,并告诉我这是否是您想要的:

    String input = "123";
    String winner = "321";
    char[] inputArr = input.toCharArray();
    Arrays.sort(inputArr);
    char[] winnerArr = winner.toCharArray();
    Arrays.sort(winnerArr);
    boolean retval = Arrays.equals(inputArr, winnerArr);
    System.out.println(retval);

这里有一个小提示代码片段,可以帮助您解决问题。

Pattern pattern = Pattern.compile(".*[^1-3].*");
   String [] inputs = {"123", "-123" , "123.12", "abcd123"};
   for(String input: inputs){
       System.out.println( "does " + input + " is number : "
                            + !pattern.matcher(input).matches());
   }
   // Regular expression in java to check if String is 6 digit number or not
   String [] numbers = {"123", "123" };
   Pattern digitPattern = Pattern.compile("\d{3}");       

相关内容

最新更新