strstr是从左向右寻找,但如果我想编一个从右向左寻找第n次出现的子序列该如何实现
1条回答 默认 最新
关注 要从右向左寻找第n次出现的子序列,可以使用以下步骤:
- 使用strlen()函数获取主序列的长度。
- 从主序列的末尾开始循环,使用strstr()函数在主序列中查找子序列。
- 如果找到了子序列,计数器加1。
- 如果计数器等于n,返回该位置。
- 如果循环结束,但是没有找到第n次出现的子序列,返回NULL。
例:
char *find_nth_substring(char *main, char *sub, int n) { int main_len = strlen(main); int sub_len = strlen(sub); int count = 0; for (int i = main_len - 1; i >= 0; i--) { char *p = strstr(main + i, sub); if (p != NULL) { count++; if (count == n) { return p; } } } return NULL; }
C++简化
int find_nth_substring(string main, string sub, int n) { int pos = -1; for (int i = 0; i < n; i++) { pos = main.rfind(sub, pos); if (pos == string::npos) return -1; } return pos; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
- ¥30 深度学习,前后端连接
- ¥15 孟德尔随机化结果不一致
- ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
- ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
- ¥15 谁有desed数据集呀
- ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
- ¥15 关于#hadoop#的问题
- ¥15 (标签-Python|关键词-socket)
- ¥15 keil里为什么main.c定义的函数在it.c调用不了