遍历字符串 返回字符重复出现的次数

遍历字符串 返回字符重复出现的次数

 

 NSString *string = [NSString stringWithFormat:@"liugang"];

 char g = 'g';



+(NSInteger)CharInNSString:(NSString *)string Char:(char)c

{

    NSInteger x = 0;

    for (int i = 0; i < [string length]; i++) {

        if ((char)[string characterAtIndex:i] == c ) {

            NSLog(@"%c",(char)[string characterAtIndex:i]);

            x++;

        }

    }

    return x;

}

字符串方法characterAtIndex 可以获取字符串下标对应字符 返回类型为unichar

[string length]返回字符串长度

(char)[string characterAtIndex:i] 返回字符串下标对应字符输出格式化为char 用%C来接

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用 JS 后缀数组方法实现遍主串所有子串并返回重复子串和重复次数的代码: ```javascript function findRepeatSubstr(str) { let suffixArr = buildSuffixArray(str); // 构建后缀数组 let maxRepeatCount = 0; // 最大重复次数 let repeatSubstrs = new Set(); // 重复子串集合 for (let i = 0; i < suffixArr.length - 1; i++) { let j = i + 1; let repeatCount = 0; // 当前重复次数 // 比较相邻后缀 while (suffixArr[i].startsWith(suffixArr[j]) || suffixArr[j].startsWith(suffixArr[i])) { repeatCount++; j++; // 更新最大重复次数重复子串集合 if (repeatCount > maxRepeatCount) { maxRepeatCount = repeatCount; repeatSubstrs.clear(); repeatSubstrs.add(suffixArr[i].substring(0, repeatCount)); } else if (repeatCount === maxRepeatCount) { repeatSubstrs.add(suffixArr[i].substring(0, repeatCount)); } } } return { repeatSubstrs: Array.from(repeatSubstrs), maxRepeatCount }; } // 构建后缀数组 function buildSuffixArray(str) { let suffixes = []; for (let i = 0; i < str.length; i++) { suffixes.push(str.slice(i)); } suffixes.sort(); let suffixArr = suffixes.map(suffix => str.length - suffix.length + 1); return suffixArr; } ``` 该函数接受一个字符串作为参数,并返回一个对象,包含重复子串和重复次数。其中,重复子串以数组形式返回重复次数为一个整数。 例如,对于字符串 `"banana"`,调用 `findRepeatSubstr("banana")` 将返回以下结果: ```javascript { repeatSubstrs: ['an'], maxRepeatCount: 2 } ``` 表示字符串中有一个重复子串 `"an"`,重复了两次。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值