• LeetCode--Minimum Window Substring


    Given a string s ang string t, find the minmum window in s.

    For example:

    s = "ADOBENCODEBANC";

    t = "ABC";

    Minimum window is "BANC";

    t = "ABBC";

    Minimum window is "BENCODEBA";

    我的时间复杂度为O(n2),不是优秀的实现代码,但是也花了我很长时间,我还是想把代码贴出来

    思路:找到字符串中第一匹配的字符和最后一个匹配的字符,两者相减之后再加1就是要找的结果(作为哨兵),但这结果并不一定是最优的,还得继续得到下一次结果,然后比较两次结果取最短的,如此循环下去,每次匹配到t中的字符,我就将t中的这个字符删掉,当t的长度小于1时,从字符串中截出第一匹配的字符和最后一个匹配的字符。

    public static void main(String[] args) {
      String s = "ADOBENCODEBANC";
      String t = "ABBC";
      String result = s;
      for(int i = 0; i < s.length(); ++i){
        result = findMinSubstring(s.substring(i), t, result);
      }
      if(result.length() == s.length() && result != t){
      System.out.println("");
      }else{
        System.out.println(result);
      }
    }

    public static String findMinSubstring(String s, String t, String result) {
      StringBuffer sb = new StringBuffer(t);
      int firstNum = -1;
      int lastNum = -1;
      for(int i = 0; i < s.length(); ++i){
        if(t.contains(s.charAt(i)+"")){
          firstNum = i;
          break;
        }
      }
      for(int j = firstNum; j < s.length(); ++j){
        if(t.contains(s.charAt(j)+"")){
          lastNum = j;
          if(sb.toString().contains(s.charAt(j)+""))
          sb.deleteCharAt(sb.toString().indexOf(s.charAt(j)));
        }
        if(sb.length() < 1){
          return s.substring(firstNum, lastNum + 1).length() < result.length() ? s.substring(firstNum, lastNum + 1) : result;
        }
      }
      return result;
    }

  • 相关阅读:
    2019.6.20刷题统计
    36 线程 队列 守护线程 互斥锁 死锁 可重入锁 信号量
    35 守护进程 互斥锁 IPC 共享内存 的方式 生产者消费者模型
    34 进程 pid ppid 并发与并行,阻塞与非阻塞 join函数 process对象 孤儿进程与僵尸进程
    33 udp 域名 进程
    32 粘包 文件传输
    31 socket客户端. 服务器 异常 语法
    30 网络编程
    29 元类 异常
    26 封装 反射 常用内置函数
  • 原文地址:https://www.cnblogs.com/huaiyinxiaojiang/p/6485142.html
Copyright © 2020-2023  润新知