词典比较两个字符串



我试图找出从输入中获取的长度为 z 的字典学最小和最大子字符串。我不知道为什么,但是在我试图找到最小子字符串的地方,if 条件不起作用。

import java.io.*;
import java.util.*;
public class Solution {
    public static void main(String[] args) {
        Scanner ip=new Scanner(System.in);
        String s=ip.next();
        int z=ip.nextInt();
        String max="";
        String mini="";
        String x="";
        for(int i=0;i<s.length()-z;i++) {
                x=s.substring(i,i+z);
                if(x.compareTo((mini))<0) //this is not working
                    mini=x;
                if(x.compareTo((max))>0)
                    max=x;
            }
        System.out.print(mini);
        System.out.print(max);
    }
}

声明两个变量minimax

的问题

您已经将它们初始化为空字符串,因此在将它们与x进行比较时,条件不会返回预期结果,并且它们的值不会更改

您可以初始化它们:

 mini = s.substring(0, z);
 max  = s.substring(0, z);

编辑

如果您尝试测试此条件:

x.compareTo((""))它将始终返回大于0的值,因此mini在任何情况下都不会更改。

相关内容

  • 没有找到相关文章

最新更新