【无标题】两个相同字符串中不同字符的个数

这道题我不会做的点就在与不知道相同字符中间不同字符的个数该如何表示,看了老师给我讲,我才明白先让哈希计数器中,每个元素都标记为-1.表示出现过一次,然后将下标赋值给只出现过一次的元素,假如这个数字出现过第二次,那么它的值就不是-1.就要用i-hash[s[i]]-1;

复制代码
class Solution {
public:
    int maxLengthBetweenEqualCharacters(string s) {
        int hash[256];
        int max=-1;
        memset(hash,-1,sizeof(hash));
        for(int i=0;i<s.size();i++){
            if(hash[s[i]]==-1){
                hash[s[i]]=i;
            }
            else{
                int x=i-hash[s[i]]-1;
                if(x>max){
                    max=x;
                }
            }
        }
        return max;
    }
};
相关推荐
Chat_zhanggong34523 分钟前
主推NT98336BG作用有哪些?
嵌入式硬件·算法
Run_Teenage42 分钟前
算法:线段树
算法
Westward-sun.44 分钟前
YOLOv2算法全方位解析:从BatchNorm到聚类先验框的九大改进
算法·yolo·聚类
扶苏xw1 小时前
【离散化算法】
算法
码之气三段.1 小时前
Codeforces Round 1095 (Div. 2) 补题
算法
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 189. 轮转数组 | C++ 三次反转经典魔法 (O(1) 空间)
c++·算法·leetcode
wuweijianlove1 小时前
算法可扩展性建模与渐进性能分析的技术7
算法
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题】【Java基础篇】第21题:HashMap和Hashtable的区别是什么
java·开发语言·面试·哈希算法·散列表·hash table
shehuiyuelaiyuehao1 小时前
算法14,滑动窗口,找到字符串中所有字母异位词
算法
凯瑟琳.奥古斯特1 小时前
图论核心考点精讲
开发语言·数据结构·算法·排序算法·哈希算法