Implement strStr()

/**
 * Implement strStr().
 * 
 * Return the index of the first occurrence of needle in haystack, or -1 if
 * needle is not part of haystack.
 * 
 * 实现Java的indxOf
 */
public class Lc28 {
    /**
     * 正常的逻辑比较,尽量不使用原来的api
     * 
     * @param haystack
     * @param needle
     * @return
     */
    public static int strStr(String haystack, String needle) {
        boolean haystackIsNUll = "".equals(haystack);
        boolean needleIsNUll = "".equals(needle);         if (!haystackIsNUll && !needleIsNUll) {         } else if (!needleIsNUll) {
            return -1;
        } else {
            return 0;
        }         char chHaystack[] = haystack.toCharArray();
        char chNeedle[] = needle.toCharArray();         int count = chNeedle.length;
        int temp = 0;
        for (int i = 0; i < chHaystack.length; i++) {
            if (chHaystack[i] == chNeedle[0]) {
                temp = i;
                for (int j = 0; j < chNeedle.length && temp < chHaystack.length; j++, temp++) {
                    if (chHaystack[temp] == chNeedle[j]) {
                        count--;
                    } else {
                        break;
                    }
                }
            }
            if (count == 0) {
                return i;
            } else {
                count = chNeedle.length;
            }
        }
        return -1;
    }     /**
     * 以被比较的字符串作为固定步长,每次直接比较对应长度字符串,比较的次数为俩个字符串的差值。
     * @param haystack
     * @param needle
     * @return
     */
    public static int strStr2(String haystack, String needle) {
        boolean haystackIsNUll = "".equals(haystack);
        boolean needleIsNUll = "".equals(needle);         if (!haystackIsNUll && !needleIsNUll) {         } else if (!needleIsNUll) {
            return -1;
        } else {
            return 0;
        }         char chHaystack[] = haystack.toCharArray();
        char chNeedle[] = needle.toCharArray();         int len = chHaystack.length - chNeedle.length;
        for (int i = 0; i <= len; i++) {
            if (haystack.substring(i, chNeedle.length + i).equals(needle)) {
                return i;
            }
        }
        return -1;
    }     public static void main(String[] args) {
        String haystack = "bbaa";
        String needle = "aab";
//        System.out.println(strStr(haystack, needle));
        System.out.println(strStr2(haystack, needle));
    }
}

Longest Common Prefix

/**
 * Write a function to find the longest common prefix string amongst an array of
 * strings.
 * 
 * If there is no common prefix, return an empty string "".
 *
 *找出所有字符串共有的前缀字符出啊
 */
public class Lc14 {
    public static String longestCommonPrefix(String[] strs) {
        if (strs.length == 0) {
            return "";
        }         //优化 找到最小长度字符串作为前缀与其他单词比较
        String prefix = strs[0];
        for (int i = 0; i < strs.length; i++) {
            if (prefix.length() > strs[i].length()) {
                prefix = strs[i];
            }
        }         //比较前缀和其他单词
        for (int i = 0; i < strs.length; i++) {
            while (strs[i].indexOf(prefix) != 0) {
                prefix = prefix.substring(0, prefix.length() - 1);
                if (prefix.isEmpty()) {
                    return "";
                }
            }
        }
        return prefix;
    }     public static void main(String[] args) {
        String[] strs = { "flower", "flow", "flight" };
        System.out.println(longestCommonPrefix(strs));
    }
}

Length of Last Word

/**
 * Given a string s consists of upper/lower-case alphabets and empty space
 * characters ' ', return the length of last word in the string.
 * 
 * If the last word does not exist, return 0.
 * 
 * Note: A word is defined as a character sequence consists of non-space
 * characters only.
 *
 */
public class Lc58 {     /*
     * 常规思路:遍历字符串,找到连续的字符个数
     */
    public static int lengthOfLastWord(String s) {
        if (s.length() == 0 || " ".equals(s)) {
            return 0;
        }         char[] chs = s.trim().toCharArray();
        int len = 0;
        for (int i = 0; i < chs.length; i++) {
            if ((chs[i] >= 'a' && chs[i] <= 'z') || (chs[i] >= 'A' && chs[i] <= 'Z')) {
                len++;
            } else if (chs[i] == ' '&&i==chs.length-1) {
                if (len > 0) {
                    return len;
                }
            }else if(chs[i] == ' '){
                len = 0;
            }
        }
        return len;
    }     //利用api直接计算
    public static int lengthOfLastWord1(String s) {
        return s.trim().length() - s.trim().lastIndexOf(" ") - 1;
    }     public static void main(String[] args) {
        String str = "Today is a nice day";
//        System.out.println(lengthOfLastWord(str));
        System.out.println(lengthOfLastWord1(str));
    }
}

First Unique Character in a String

import java.util.LinkedHashMap;
import java.util.Map; /**
 * Given a string, find the first non-repeating character in it and return it's
 * index. If it doesn't exist, return -1.
 */
public class Lc387 {
    /**
     * 通过map存储各个字符出现爱你的个数
     * 注意用linkHashMap,hashmap会自动排序
     * @param s
     * @return
     */
    public static int firstUniqChar(String s) {
        if ("".equals(s)) {
            return -1;
        }
        char[] chs = s.toCharArray();
        Map<Character, Integer> map = new LinkedHashMap<Character, Integer>();
        for (int i = 0; i < chs.length; i++) {
            Character key = chs[i];
            if (map.containsKey(key)) {
                Integer count = map.get(key);
                map.put(key, ++count);
            } else {
                map.put(key, 1);
            }
        }         Character firstC = ' ';
        for (Map.Entry<Character, Integer> entry : map.entrySet()) {
            if (entry.getValue() == 1) {
                firstC = entry.getKey();
                break;
            }
        }         for (int i = 0; i < chs.length; i++) {
            if (chs[i] == firstC) {
                return i;
            }
        }         return -1;
    }     /**
     * 照比方法优化是使用了api快了几毫秒
     * @param s
     * @return
     */
    public static int firstUniqChar1(String s) {
        if ("".equals(s)) {
            return -1;
        }
        char[] chs = s.toCharArray();
        Map<Character, Integer> map = new LinkedHashMap<Character, Integer>();
        for (int i = 0; i < chs.length; i++) {
            Character key = chs[i];
            if (map.containsKey(key)) {
                Integer count = map.get(key);
                map.put(key, ++count);
            } else {
                map.put(key, 1);
            }
        }         Character firstC = ' ';
        for (Map.Entry<Character, Integer> entry : map.entrySet()) {
            if (entry.getValue() == 1) {
                firstC = entry.getKey();
                break;
            }
        }
        return s.indexOf(firstC);     }     public static void main(String[] args) {
        String s = "loveleetcode";
        System.out.println(firstUniqChar(s));
    }
}

Ransom Note

import java.util.HashMap;
import java.util.Map; /**
 * 勒索信
 * 匹配ransomNote中的字符是否能在magazine中找到 
 *
 */
public class Lc383 {     public static boolean canConstruct(String ransomNote, String magazine) {
        if (!"".equals(ransomNote) && "".equals(magazine)) {
            return false;
        }
        char[] chs = magazine.toCharArray();
        Map<Character, Integer> map = new HashMap<Character, Integer>();
        for (char key : chs) {
            if (map.containsKey(key)) {
                Integer count = map.get(key);
                map.put(key, ++count);
            } else {
                map.put(key, 1);
            }
        }         char[] chsRansonNote = ransomNote.toCharArray();
        for (char c : chsRansonNote) {
            int count = 0;
            count = map.get(c) != null ? map.get(c) : 0;
            count--;
            map.put(c, count);
            if (count < 0) {
                return false;
            }
        }
        return true;     }     public static void main(String[] args) {
        String ransomNote = "";
        String magazine = "a";
        System.out.println(canConstruct(ransomNote, magazine));
    }
}

Reverse String

/**
 *反转字符串 
 *
 */
public class Lc344 {
    public static void reverseString(char[] s) {
        for (int i = 0; i < Math.round(s.length / 2); i++) {
            char temp = s[i];
            s[i] = s[s.length - 1 - i];
            s[s.length - 1 - i] = temp;
        }
    }     public static void main(String[] args) {
        char[] s = { 'h', 'e', 'l', 'l', 'o' };
        reverseString(s);     }
}

leetcode-字符串篇的更多相关文章

  1. c++ LeetCode (初级字符串篇) 九道算法例题代码详解(二)

    原文作者:aircraft 原文链接:https://www.cnblogs.com/DOMLX/p/11089327.html 已经刷了很多篇leetcode题了,不过最近在找c++的实习工作(大佬 ...

  2. LeetCode 字符串专题(一)

    目录 LeetCode 字符串专题 <c++> \([5]\) Longest Palindromic Substring \([28]\) Implement strStr() [\(4 ...

  3. 【leetcode 字符串处理】Compare Version Numbers

    [leetcode 字符串处理]Compare Version Numbers @author:wepon @blog:http://blog.csdn.net/u012162613 1.题目 Com ...

  4. LeetCode刷题总结-字符串篇

    本文梳理对LeetCode上有关字符串习题的知识点,并给出对应的刷题建议.本文建议刷题的总数为32题.具体知识点如下图: 1.回文问题 题号:5. 最长回文子串,难度中等 题号:214. 最短回文串, ...

  5. Leetcode初级算法(字符串篇)

    目录 反转字符串 颠倒整数 字符串中的第一个唯一字符 有效的字母异位词 验证回文字符串 实现strStr() 数数并说 最长公共前缀 字符串转整数(atoi) 反转字符串 和vector同样的进行sw ...

  6. leetcode 字符串类型题

    1,Vaild Palindrome bool isPalindrome(string& s) { transform(s.begin(), s.end(), s.begin(), tolow ...

  7. leetcode 字符串中的第一个唯一字符

    给定一个字符串,找到它的第一个不重复的字符,并返回它的索引.如果不存在,则返回 -1. 案例: s = "leetcode" 返回 0. s = "loveleetcod ...

  8. leetcode 字符串动态规划总结

    问题1:leetcode 正则表达式匹配 请实现一个函数用来匹配包括'.'和'*'的正则表达式.模式中的字符'.'表示任意一个字符,而'*'表示它前面的字符可以出现任意次(包含0次). 在本题中,匹配 ...

  9. golang基础教程——字符串篇

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是golang专题的第6篇文章,这篇主要和大家聊聊golang当中的字符串的使用. 字符串定义 golang当中的字符串本质是只读的字符 ...

  10. C#之字符串篇

    大杂烩 一.类型转换    字符串转整形: int a = int.Parse(""); //不能转换null int b = Convert.ToInt32("&quo ...

随机推荐

  1. 2.成产出现 max(vachar2)取值问题

    uat 测试结果正确max(9)>max(8),结果生产出现 max(9)>max(12) 原因:字符类型,默认比较第一个字符的ASCII码. 解决方式: max(to_number(va ...

  2. 初步了解JVM第二篇

    在一篇<初步了解JVM第一篇>中,我们已经了解了: 类加载器:负责加载*.class文件,将字节码内容加载到内存中.其中类加载器的类型有如下: 启动类加载器(Bootstrap) 扩展类加 ...

  3. springcloud-eureka高可用集群搭建

    一 前言 eureka作为注册中心,其充当着服务注册与发现功能,加载负载均衡:若在项目运行中eureka挂了,那么整个服务整体都会暂停,所以为服务运行的安全性,有必要搭建eureka集群:当其中一个e ...

  4. LeetCode刷题总结-栈、链表、堆和队列篇

    本文介绍LeetCode上有关栈.链表.堆和队列相关的算法题的考点,推荐刷题20道.具体考点分类如下图: 一.栈 1.数学问题 题号:85. 最大矩形,难度困难 题号:224. 基本计算器,难度困难 ...

  5. d3.js 教程 模仿echarts折线图

    今天我们来仿echarts折线图,这个图在echarts是折线图堆叠,但是我用d3改造成了普通的折线图,只为了大家学习(其实在简单的写一个布局就可以).废话不多说商行代码. 1 制作 Line 类 c ...

  6. Winform中使用Timer实现滚动字幕效果(附代码下载)

    场景 效果 注: 博客主页: https://blog.csdn.net/badao_liumang_qizhi 关注公众号 霸道的程序猿 获取编程相关电子书.教程推送与免费下载. 实现 新建一个Fo ...

  7. BOM对象——Navigator

    BOM对象--Navigator <!DOCTYPE html> <html> <head> <meta charset="utf-8"& ...

  8. 【Linux 命令】cp 命令详解

    Linux 命令之 cp 命令详解 一.cp 命令简介 cp 命令主要用于复制文件或目录.即用来将一个或多个源文件或者目录复制到指定的目的文件或目录. cp 命令可以将单个源文件复制成一个指定文件名的 ...

  9. JUC-5-CountDownLatch 闭锁

      CountDownLatch 闭锁 同步辅助类 一组操作中,多个线程完成,  闭锁会允许一个或多个线程一直等待.   即 所有线程都完成才继续执行  

  10. Power BI 概念及 国内版Pro 试用账户注册流程

    视频内容: Power BI 基本概念:https://v.qq.com/x/page/s3026nn69eu.html Power BI Pro 世纪互联版本试用账号注册:https://v.qq. ...