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

扬州鼎盛开发建设有限公司网站100个电商平台

扬州鼎盛开发建设有限公司网站,100个电商平台,菜鸟做网站,大龄程序员都干啥去了力扣 3 无重复字符的最长字串 题目描述 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。 示例 1: 输入: s "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。示例 2: 输入: s…

力扣 3 无重复字符的最长字串

题目描述

给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。

示例 1:

输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。

示例 2:

输入: s = "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。

示例 3:

输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。

提示:

  • 0 <= s.length <= 5 * 104
  • s 由英文字母、数字、符号和空格组成

思路分析

关于这道题用滑动窗口的思想来做的话会非常麻烦,既要考虑最长的字串长度,同时还要保证不出现重复字符(考虑窗口里的每一个字符不重复),我们可以用一个非常巧妙的思路

这个思路利用了关于哈希算法以及字符的ascii编码来进行。我们首先定义一个数组名为hash,容量为256的数组,初始化为0。随后开始遍历整个字符串,这里需要两层循环,利用每一个字符的ascii编码当作数组的下标,如果下标对应的值为零,我们设置为1,并进入下面if语句的运行,如果下一个字符和它相等,就不会进入接下来的判断,这是判断不出现重复字符的方法。

关于求最长的字串长度,我们利用两个下标,从第一个字符开始,如果接下来的字符对应的下标的数组为0就进入if语句,此时遍历的两个下标的差值在加上原来的第一个字符(也算不重复的字串)便是不出现重复字符字串的长度,同时定义一个max值保留每一次的最大值即可。

完整代码

int lengthOfLongestSubstring(char* s) {int j=0;int i=0;int max=1;int n=strlen(s);if(n==0){return 0;}for(i=0;i<n;i++){int hash[256]={0};for(j=i;j<n;j++){if(hash[s[j]]==0){hash[s[j]]=1;if(j-i+1>max){max=j-i+1;}}else{break;}}}return max;}

http://www.15wanjia.com/news/5237.html

相关文章:

  • 网站做app安全吗深圳全网信息流推广公司
  • 福田网站建设龙岗网站建设龙岗网站建设龙岗网站建设百度关键词怎么刷上去
  • 2022年楼市最新政策优化落实新十条措施
  • 公司动态网站模板下载百度公司注册地址在哪里
  • 做兼职一般去哪个网站好seo论坛
  • 电商网站开发流程代码东莞全网推广
  • 襄阳住房和城乡建设网站win10优化大师好用吗
  • 南宁做网站价格制作网站需要什么
  • 淘宝上做网站不靠谱网站服务器查询
  • 小程序自己做网站seo优化博客
  • 胜芳哪里做网站公司seo
  • 世界上做的最好的前端网站官方网站怎么注册
  • 濮阳做网站多少钱谷歌seo建站
  • 南通给公司做网站的今天疫情最新消息
  • 有专门做网站的公司吗推广公司属于什么公司
  • wordpress 安装包金融网站推广圳seo公司
  • 党建网站怎么做百度推广靠谱吗
  • 织梦移动网站模板郑州网络推广哪家口碑好
  • 重庆蜡像制作优化公司
  • 韦恩图在线制作网站seo快速上排名
  • 公司网站建设工作总结营销推广技巧
  • c mvc 大型网站开发公司怎么建立自己的网站
  • 虾皮网站有的做吗有什么引流客源的软件
  • 计算机编程是做网站如何推广一个新的app
  • 怎样做后端数据传输前端的网站海外短视频跨境电商平台是真的吗
  • 这几年做哪些网站致富黑帽seo什么意思
  • 网站怎么做自适应权威发布
  • 做网站营业范围石家庄网络推广平台
  • 宁波网站建设专业定制综合搜索引擎
  • wordpress5.0启多站点腾讯企业邮箱登录入口