LeetCode#524通过删除字母匹配到字典里最长单词-java中CompareTo方法用法以及Comparator中Compare方法返回值

摘要:
如果有多个答案,则返回长度最长且字典顺序最低的字符串。示例1:输入:s=“abpcpley”,d=[“ale”,“apple”,“monkey”,“pley”]输出:“苹果”示例2:输入:s=“abPCpley”、d=[”a“,”b“,”c“]输出:”a“描述:所有输入字符串仅包含小写字母。字典的大小不能超过1000。所有输入字符串都不能超过1000*/publicclassp524{/*publicStringfindLongestWord{Collections.sort(d,newComparator<String>(){@Overridepublicintcompare(Stringo1,Stringo2){if(o1.length()!
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

/*
524. 通过删除字母匹配到字典里最长单词
给定一个字符串和一个字符串字典,找到字典里面最长的字符串,该字符串可以通过删除给定字符串的某些字符来得到。如果答案不止一个,返回长度最长且字典顺序最小的字符串。如果答案不存在,则返回空字符串。

示例 1:

输入:
s = "abpcplea", d = ["ale","apple","monkey","plea"]

输出:
"apple"
示例 2:

输入:
s = "abpcplea", d = ["a","b","c"]

输出:
"a"
说明:

所有输入的字符串只包含小写字母。
字典的大小不会超过 1000。
所有输入的字符串长度不会超过 1000
 */
public class p524 {
    /*public String findLongestWord(String s, List<String> d) {
        Collections.sort(d, new Comparator<String>() {
            @Override
            public int compare(String o1, String o2) {
                if(o1.length()!=o2.length()){
                    return o2.length()-o1.length();
                }
                else {
                    int len=o1.length();
                    return o1.compareTo(o2);
                }
            }
        });
        String res="";
        for(String str:d){
            if(isChildXulie(s,str))return str;
        }
        return res;


    }*/
    public String findLongestWord(String s, List<String> d){
        String res="";
        for(String str:d){
            if(isChildXulie(s,str)){
                int len=str.length();
                if(len>res.length()){
                    res=str;
                }
                else if(len==res.length()) {
                    res=res.compareTo(str)>0?str:res;

                }
            }
        }
        return res;
    }
    public boolean isChildXulie(String s1,String s2){//判断S2是不是s1的子序列
        int j=0;
        for(int i=0;i<s1.length();i++){
            if(j<s2.length()&&s1.charAt(i)==s2.charAt(j)){
                j++;
            }

        }
        if (j==s2.length()){
            return true;
        }
        return false;
    }

}

  运行结果:

注释掉的:

LeetCode#524通过删除字母匹配到字典里最长单词-java中CompareTo方法用法以及Comparator中Compare方法返回值第1张

第二种方法:

LeetCode#524通过删除字母匹配到字典里最长单词-java中CompareTo方法用法以及Comparator中Compare方法返回值第2张

CompareTo方法:

LeetCode#524通过删除字母匹配到字典里最长单词-java中CompareTo方法用法以及Comparator中Compare方法返回值第3张

LeetCode#524通过删除字母匹配到字典里最长单词-java中CompareTo方法用法以及Comparator中Compare方法返回值第4张

Comparator中Compare方法返回值:

           返回值为1则交换两个值,返回值小于等于0不做交换

免责声明:文章转载自《LeetCode#524通过删除字母匹配到字典里最长单词-java中CompareTo方法用法以及Comparator中Compare方法返回值》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇淘宝对接(一)[Android Pro] AndroidStudio IDE界面插件开发(Hello World篇)下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

动态将ASPX生成HTML网页并将网页导出PDF

1.首先要找到wnvhtmlconvert.dll这个文件,并引入项目中。 2.Server.Execute("pos.aspx?id=" + ids); 执行相应的aspx网页 3.pos.aspx网页中有这样的一个方法,此方法用来生成html页面 protected override void Render(HtmlTextWriter writer)...

Java从入门到实战之(26)Java网络实例之练习

1、获取指定主机的IP地址 如何使用 InetAddress 类的 InetAddress.getByName() 方法来获取指定主机(网址)的IP地址? package Java_Learn.File; import java.net.InetAddress; import java.net.UnknownHostException; public...

【决策树】— C4.5算法建立决策树JAVA练习

以下程序是我练习写的,不一定正确也没做存储优化。有问题请留言交流。转载请挂连接。 当前的属性为:age income student credit_rating 当前的数据集为(最后一列是TARGET_VALUE): --------------------------------- youth     high   no   fair      no y...

java把一段时间分成周,月,季度,年的时间段

package com.mq.test.activeMQ; import java.text.DateFormat; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date;...

String的intern方法的用处

今天第一次翻看Effective java,在其第一个item中讲静态工厂方法的有点的时候说到“它们每次被调用 的时候,不要非得创建一个新的对象”并在结尾处提到---"String.intern方法以一种有限的形式实现了这 种优化",由于以前没用过intern这个方法,所以去查了查,并把自己的理解写下来供以后参考首先来看其中文API的描述: intern...

C#正则表达式合并连续空格为单个空格

第一种方法:       使用 System.Text.RegularExpressions.Regex.Replace()方法   string result = String.Empty;   string str = "Just     Test the  Method";   result = Regex.Replace(str, "\s{2,}"...