当前位置: 首页 > news >正文

建设一个网站的基本成本中国企业500强

建设一个网站的基本成本,中国企业500强,旧房装修,8图片这样的网站怎么做的作者:翟天保Steven 版权声明:著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处 题目描述: 请从字符串中找出一个最长的不包含重复字符的子字符串,计算该最长子字符串的长度。 数据范围…

作者:翟天保Steven
版权声明:著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处

题目描述:

请从字符串中找出一个最长的不包含重复字符的子字符串,计算该最长子字符串的长度。

数据范围:

 s.length≤40000 s.length≤40000

示例:

输入:

"abcabcbb"

返回值:

3

说明:

因为无重复字符的最长子串是"abc",所以其长度为 3。 

解题思路:

本题是动态规划的经典题目。有两个解题思路。

思路一:滑动窗口

  1. 设计一个滑动窗口,窗口的右边界先行,用哈希表统计字符出现次数。
  2. 当出现重复字符时,左边界出发缩小窗口直到重复字符消失。
  3. 持续刷新最值就可以了。

思路二:动态规划

  1. 用哈希表存放字符上次出现的位置下标;用长度比字符串大1的vector,存放截止到第i个字符时,能继续维持的子串长度,比如v[0]=0,v[1]=1,v[2]可能为1可能为2。
  2. 执行遍历。用哈希表判断当前字符是否为重复字符,如果不是重复字符,那就在前面子串长度基础上加1;若出现了重复字符,则该字符与其重复字符的距离为i-m[s[i]],但如果两者之间有别的重复字符,则需要考虑此类情况,可以认为在其重复字符之后的子串中,该字符未出现过,则有v[i]+1;所以,比较v[i]+1和i-m[s[i]]谁小取谁,因为小的子串没断开,后续可以继续连接,而断开的子串虽然长度大,但不可以继续增加了。
  3. 持续更新字符最新下标以及子串长度最大值。

测试代码:

思路一:滑动窗口

class Solution {
public:// 最长子串int lengthOfLongestSubstring(string s) {// 定义哈希表unordered_map<char, int> m;// 滑动窗口遍历int result = 0;for(int left = 0, right = 0; right < s.length(); ++right){// 窗口右边界先行,统计字符出现次数m[s[right]]++;// 当出现重复字符,窗口左边界右移缩小窗口直到重复字符消失while(m[s[right]] > 1){m[s[left]]--;left++;}// 持续刷新子串最大长度result = max(result, right - left + 1);}return result;}
};

思路二:动态规划

class Solution {
public:// 最长子串int lengthOfLongestSubstring(string s) {// 定义哈希表,存放的是字符出现的位置下标unordered_map<char, int> m;int result = 0;// v[i]表示截止到i个字符时,能继续维持的子串长度// 所以v[0]=0,v[1]=1vector<int> v = vector<int>(s.length() + 1, 0);// i是字符串中字符下标for(int i = 0; i < s.length(); ++i){// 当哈希表中没发现重复字符,那就在前面最长子串长度基础上+1if(m.find(s[i]) == m.end())v[i + 1] = v[i] + 1;// 若出现了重复字符,该字符与其重复字符的距离为i-m[s[i]]// 但如果两者之间有别的重复字符,那要考虑这类情况// 可以认为在其重复字符之后的子串中,该字符未出现过,则有v[i]+1// 所以v[i]+1和i-m[s[i]]谁小,取谁,因为小的这个子串没断开elsev[i + 1] = min(v[i] + 1, i - m[s[i]]);// 刷新该字符最新下标m[s[i]] = i;// 刷新最值result = max(result, v[i + 1]);}return result;}
};

http://www.mmbaike.com/news/82097.html

相关文章:

  • 上海找做网站公司好如何在百度做推广
  • 网站空间不支持php5.4个人网站创建平台
  • 网站开发的意义网站内部优化有哪些内容
  • 淘宝客网站哪里可以做今日国内新闻热点
  • 广州 网站开发 公司百度站长收录入口
  • 网站返回首页怎么做的好看杭州网站推广优化
  • 做微信公众号第三网站最新的疫情情况
  • 哈尔滨做设计和网站的公司吗怎么做app推广和宣传
  • 网站设置密码进入短视频关键词优化
  • 企业手机建站系统建站公司哪个好
  • 中国建设银行网站官网下载安装搜索引擎bing
  • 合肥做网站123cms搜索引擎收录提交入口
  • 橙子建站广告怎么收费百度seo一本通
  • 电子商务网站开发费用今日新闻7月1日
  • 南宁做网站找哪家长春网站快速优化排名
  • 企业手机网站源码新站网站推广公司
  • 素材下载网站开发文档seo1短视频网页入口营销
  • 一个一起做网站石家庄疫情防控最新政策
  • 怎么用自己的电脑做服务器发布网站厨师培训学校
  • 东莞企业营销型网站建设网络服务商主要包括哪些
  • 戴尔电脑网站建设方案范文百度联盟怎么加入
  • 深圳网站建设培训班市场调研的方法
  • 深圳做外贸网站公司百度广告点击一次多少钱
  • 华为云怎么做网站青岛网站建设制作推广
  • 网站首页psd格式怎么做关键词完整版
  • 珠海制作公司网站搜狗网页
  • 怎么做兼职网站吗优化服务是什么意思
  • 大连网站推广爱得科技亚洲卫星电视网参数表
  • 南宁企业建站系统爱站网seo培训
  • 网络服务商是谁怎么优化关键词