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

这道题我不会做的点就在与不知道相同字符中间不同字符的个数该如何表示,看了老师给我讲,我才明白先让哈希计数器中,每个元素都标记为-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;
    }
};
相关推荐
csdn_aspnet12 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
m0_6294947315 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户15 小时前
用队列实现栈
数据结构·算法
做人求其滴15 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
daad77715 小时前
记一组无人机IMU传感器数据
算法
计算机安禾15 小时前
【c++面向对象编程】第42篇:模板特化与偏特化:为特定类型定制实现
开发语言·c++·算法
小O的算法实验室15 小时前
2026年KBS,流形感知强化学习差分进化算法+不规则3D无人机路径规划,深度解析+性能实测
算法·智能算法·智能算法改进
玖釉-16 小时前
C++ 中的循环语句详解:while、do...while、for、嵌套循环与循环控制
开发语言·c++·算法
不做无法实现的梦~16 小时前
运动控制系统复习一览-----常考题目总结版本
算法