首页 > Windows开发 > 详细

Minimum Window Substring

时间:2016-08-02 17:00:20      阅读:322      评论:0      收藏:0      [点我收藏+]

技术分享

这题还是很有难度的。通过数组记录元素的长度,将目标数组与其进行比较,再对相应的子串进行缩小,并记录相应的起点与长度。

技术分享
string minWindow(string S, string T)
      {
          if (S.empty())return " ";
          if (S.size() < T.size())return " ";

          const int ASCII_MAX = 256;
          //定义数组,表示相应字符出现的次数
          int appeared_count[ASCII_MAX];
          int expected_count[ASCII_MAX];
          fill(appeared_count, appeared_count + ASCII_MAX, 0);
          fill(expected_count, expected_count + ASCII_MAX, 0);
          //统计目标串每个元素出现的次数
          for (int i = 0; i < T.size(); i++)expected_count[T[i]]++;
          
          int minWidth = INT_MAX, min_start = 0;//记录窗口大小,起点
          int wnd_start = 0;
          int appeared = 0;//

          //不断向后扫描
          for (int wnd_end = 0; wnd_end < S.size(); wnd_end++)
          {
              //如果当前元素在目标串中
              if (expected_count[S[wnd_end]]>0)
              {
                  //相应元素出现次数加1
                  appeared_count[S[wnd_end]]++;
                  //注意appeared自增的条件
                  if (appeared_count[S[wnd_end]] <= expected_count[S[wnd_end]])
                      appeared++;
              }

              if (appeared == T.size())//完整的包含了一个目标串
              {
                  //录找最小串,如果记录的某元素的数量大于目标某元素的数量,
                  //或者该元素在目标串中没有出现,则可以去掉一个
                  while (appeared_count[S[wnd_start]] > expected_count[S[wnd_start]] 
                      || expected_count[S[wnd_start]]==0)
                  {
                      appeared_count[S[wnd_start]]--;
                      wnd_start++;
                  }
                  //保留长度和起始位置
                  if (minWidth > wnd_end - wnd_start + 1)
                  {
                      minWidth = wnd_end - wnd_start + 1;
                      min_start = wnd_start;
                  }
              }

          }
          if (minWidth == INT_MAX)return " ";
          else return S.substr(min_start, minWidth);
      }
View Code

 

Minimum Window Substring

原文:http://www.cnblogs.com/573177885qq/p/5729632.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!