哈希表判断元素是否重复出现与双向指针的集合

使用哈希表判断元素是否重复出现,适用题型判断最长不重复子串,判断数字、字符不同

题目:3. 无重复字符的最长子串

伪代码:

定义一个哈希表hash

初始化右指针的值-1,初始化最长不重复子串长度0

for(i=0;i<s.length;i++)

{

         如果(左指针不是指向第一个位置)

         {

                  //向右滑动左指针

                  把左指针之前的元素从哈希表中移除;

         }

        //向右移动右指针直到和哈希表中元素重复

        while(右指针向右滑动一个不会超过末尾并且右指针向右滑动一次指向的元素不在哈希表中)

       {

                 将右指针向右滑动一次的值存入哈希表中;

                 将右指针向右滑动一次;

       }

       最长不重复子串长度=max(最长不重复子串,右指针减左指针+1);

}

返回   最长不重复子串

141. 环形链表

使用哈希表判断链表是否有环

终止条件,链表到达末尾,或者哈希表中已经有这个节点。

否则将节点不断存入哈希表。

160. 相交链表

判断A和B两条链表是否相交

先将A遍历加入哈希表;

再遍历B插入节点,如果插入失败则该节点处相交,返回该节点。

              

     

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值