假设有一个字符串aabcad,请写一段程序,去掉字符串中不相邻的重复字符串,即上述字符串处理之后的输出结果为:aabcd

这是一道关于字符串处理的问题,要求移除不相邻的重复字符,例如字符串'aabcad'处理后应为'aabcd'。文章指出网上常见解答错误,并提供了作者自己的代码实现。

朋友给我发了这个题目, 一看这种问题肯定属于网红题, 肯定网上有很多解答, 有了思路后就想网搜一下看看大家有没有其它想法, 结果翻了一圈下来, 看到的解答都是不正确的, 就自己写了些代码放上来, 仅供参考:

注: 不仅仅是要aabcad->aabcd这种结果, 所求是移除所有有重复但不相邻的, 如无相邻的则不管, 如abab->abab

/*
 aabcad -> aabcd, abbdcaabd -> bbdcaad ...
 思路:
 1. 获取每个字符出现的次数;
 2. 定位个数为2以上的每个字母的位置
 3. 记录要删除字符的位置
 4. 对应删除
 */
- (NSString *)removeTheEqualButNotNearbyCharForStr:(NSString *)fromStr {
    if (fromStr.length <= 3) return fromStr;
    
    // 统计每个字符出现的次数
    NSMutableDictionary *chatCountDict = [[NSMutableDictionary alloc] init];
    int count = 0; BOOL equal = NO;
    for (int i = 0; i < fromStr.length; i++) {
        count = 0; equal = NO;
        for (int j = 0; j < i; j++) {
            if ([fromStr characterAtIndex:i] == [fromStr characterAtIndex:j]) {
                equal = YES;
                break;
            }
        }
        if (equal) continue;
        for (int j = i; j < fromStr.length; j++) {
            if ([fromStr characterAtIndex:i] == [fromStr characterAtIndex:j]) count++;
        }
        [chatCountDict setValue:@(count) forKey:[fromStr substringWithRange:NSMakeRange(i, 1)]];
    }
    
    // 保留2个以上的字符记录
    [chatCountDict enumerateKeysAndObjectsUsingBlock:^(id  _Nonnull key, id  _Nonnull obj, BOOL * _Nonnull stop) {
        if ([obj intValue] <= 2) [chatCountDict removeObjectForKey:key];
    }];
    
    // 获取字符对应位置
    NSMutableDictionary *chatLocationDict = [[NSMutableDictionary alloc] init];
    [chatCountDict enumerateKeysAndObjectsUsingBlock:^(NSString *key, NSString *obj, BOOL * _Nonnull stop) {
        NSMutableArray *locationArr = [[NSMutableArray alloc] init];
        for (int i = 0; i < fromStr.length; i++) {
            if ([[NSString stringWithFormat:@"%c",[fromStr characterAtIndex:i]] isEqualToString:key]) [locationArr addObject:@(i)];
        }
        [chatLocationDict setValue:locationArr forKey:key];
    }];
    
    // 记录要删除字符的位置
    NSMutableArray *indexArrM = [[NSMutableArray alloc] init];
    for (int j = 0; j < chatLocationDict.allKeys.count; j++) {
        NSArray *locaArr = chatLocationDict[chatLocationDict.allKeys[j]];
        BOOL hasEqualNearBy = NO;
        for (int i = 0; i < locaArr.count - 1; i++) {
            if ([locaArr[i] intValue] + 1 == [locaArr[i + 1] intValue]) hasEqualNearBy = YES;
        }
        if (!hasEqualNearBy) continue;
        for (int i = 0; i < locaArr.count; i++) {
            if (
                (i == 0 && ([locaArr[i] intValue] + 1 != [locaArr[i + 1] intValue])) ||
                (i == locaArr.count -1 && ([locaArr[i - 1] intValue] + 1 != [locaArr[i] intValue])) ||
                (i != 0 && i != locaArr.count - 1 && (([locaArr[i] intValue] + 1 != [locaArr[i + 1] intValue]) && ([locaArr[i - 1] intValue] + 1 != [locaArr[i] intValue])))
                ) {
                [indexArrM addObject:locaArr[i]];
            }
        }
    }
    
    // 移除
    NSMutableArray *arrM = [[NSMutableArray alloc] initWithCapacity:fromStr.length];
    for (int i = 0; i < fromStr.length; i++) [arrM addObject:[NSString stringWithFormat:@"%c",[fromStr characterAtIndex:i]]];
    NSMutableIndexSet *indexSet = [[NSMutableIndexSet alloc] init];
    for (NSNumber *num in indexArrM) [indexSet addIndex:[num integerValue]];
    [arrM removeObjectsAtIndexes:indexSet];
    
    NSMutableString *strM = [[NSMutableString alloc] init];
    for (NSString *str in arrM) [strM appendString:str];
    return strM.copy;
}

下载代码方式:https://pan.quark.cn/s/a4b39357ea24 依据所提供的资料,我们深入剖析此问题以及所给出的两种算法方案。 ### 问题背景 该问题源自王晓东编撰的《算法设计与实验题解》一书,书中阐述了一个值得注意的数学议题:针对一本页码从1到n顺序编号的书籍,要求统计所有页码中数字0至9各自出现的频次。例如,若n=13,则页码序列为1、2、...、13,其中数字1出现5次(体现在1、10、11、12、13中),数字0出现1次(体现在10中)。 ### 问题描述 具体而言,我们需要开发一种算法,其输入参数为一个正整数n,输出结果需为0至9这十个数字各自出现的频次。所有页码均以十进制形式呈现,且不包含任何前导零,即不会出现如006之类的页码表示。 ### 解决方案一:时间复杂度为O(n*log10(n))的算法 首先,介绍一种时间复杂度为O(n*log10(n))的算法实现。其核心构思在于遍历从1到n的每一个数值,然后逐一分解每个数值的各个位,并统计各类数字出现的频次。具体步骤如下: 1. 初始化一个长度为10的数组`count`,用于记录0至9每个数字出现的频次,初始值均为0。 2. 从1开始遍历至n,对于每一个数值i,将其转换为整数并进行以下操作: - 利用循环结构,持续将当前数值除以10,获取余数(即当前最低位的数字),并累加到对应的计数器中。 3. 遍历完成后,输出`count`数组中的每一个元素,即为所求的结果。 ### 解决方案二:优化算法 为了提升效率,提出了一种更为优越的算法。该算法基于以下观察:在1到10^n-1之间的任意区间内,每一种数字0至9出现的频次是相等的。例如,在1到999之间,每一种数字0至9出现的频次均相...
内容概要:本文档详细介绍了基于直驱永磁同步发电机(PMSG)的1.5MW风力发电系统在Simulink环境下的建模与仿真方法,涵盖风力机、传动系统、PMSG本体及电力电子变换器等核心组件的数学建模与系统集成。通过构建完整的风电系统仿真平台,实现了对风速扰动、机械动力学响应、电磁能量转换及并网运行特性的动态模拟,重点解析了PMSG在不同工况下的运行行为与先进控制策略的设计与实现,如最大功率点跟踪(MPPT)和矢量控制技术。该模型不仅可用于风电系统的性能评估与优化,还可作为控制器设计与算法验证的有效工具,支持新能源领域的教学、科研与工程应用。; 适合人群:具备电力系统、电机控制或可再生能源发电等相关背景的科研人员、工程技术人员及高校研究生;熟悉MATLAB/Simulink仿真环境者尤佳。; 使用场景及目标:①开展风力发电系统的动态特性分析与先进控制策略研究;②完成课程设计、学位论文或科研项目中的系统建模任务;③复现高水平学术论文中的风电仿真案例,支撑科研成果的验证与发表。; 阅读建议:建议结合文档中提到的相关控制算法与优化策略进行拓展学习,重点关注模型结构搭建、参数配置与仿真调试过程,并通过改变风速输入、负载条件等变量开展多工况仿真实验,深入理解系统动态响应机制与控制效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值